# Datasheet for Telink # Multi-Standard Wireless SoC # TLSR9515 DS-TLSR9515-E5 Ver 0.8.4 2021/05/14 ## Keyword BR; EDR; Bluetooth LE; Indoor positioning; BLE Mesh; ## Brief This datasheet is dedicated for Telink multi-standard wireless audio SoC TLSR9515. In this datasheet, function block diagram, key features, and typical applications of TLSR9515 are introduced. ### Published by #### Telink Semiconductor Bldg 3, 1500 Zuchongzhi Rd, Zhangjiang Hi-Tech Park, Shanghai, China © Telink Semiconductor All Right Reserved ### Legal Disclaimer This document is provided as-is. Telink Semiconductor reserves the right to make improvements without further notice to this document or any products herein. This document may contain technical inaccuracies or typographical errors. Telink Semiconductor disclaims any and all liability for any errors, inaccuracies or incompleteness contained herein. Copyright © 2021 Telink Semiconductor (Shanghai) Co., Ltd. ### Information For further information on the technology, product and business term, please contact Telink Semiconductor Company (<a href="www.telink-semi.com">www.telink-semi.com</a>). For sales or technical support, please send email to the address of: telinkcnsales@telink-semi.com telinkcnsupport@telink-semi.com DS-TLSR9515-E5 1 Ver 0.8.4 # **Revision History** | Version | Change Description | |---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0.8.0 | Preliminary release | | 0.8.1 | <ol> <li>Add BT(BR, EDR) related information</li> <li>Update VDD to VBAT in Table 2-3 DC Characteristics(VBAT=4.2 V, T = 25 °C ), Table 2-5 RF Performance AC Characteristics(VBAT = 4.2 V, T = 25 °C )</li> <li>Add note for Table 2-4 Digital Inputs/Outputs AC Characteristics (VDD = 3.3 V, T = 25 °C)</li> </ol> | | 0.8.2 | 1. Add power consumption data of EDR mode in Table 2-3 DC Characteristics(VBAT=4.2 V, T = 25 °C ) 2. Update Modulation 20dB bandwidth for BLE 2 Mbps RF_TX performance, zigbee 250 kbps RF_TX performance, output power maximum setting for BR RF_TX performance and EDR RF_TX performance in Table 2-5 RF Performance AC Characteristics(VBAT = 4.2 V, T = 25 °C ), | | 0.8.3 | <ol> <li>Update 5 Audio, 7 Clock, 9 Interrupt System,10.1 GPIO, 16 AES</li> <li>Modify LSPI to PSPI</li> <li>Add 4.6 Charger, 13.4 Battery Voltage Sampling</li> <li>Add LDO power consumption data in 1.2.3 Features of Power Management Module, Table 2-3 DC Characteristics(VBAT=4.2 V, T = 25 °C )</li> <li>Other minor edits and corrections</li> </ol> | | 0.8.4 | 1. Add TLSR9515B related information 2. Remove TLSR9515T related information 3. Other minor corrections in GPIO functions | # Table of Contents | 1 Overview | 15 | |--------------------------------------------------|----| | 1.1 Block Diagram | 15 | | 1.2 Key Features | 16 | | 1.2.1 General Features | 16 | | 1.2.2 RF Features | 17 | | 1.2.3 Features of Power Management Module | 17 | | 1.2.4 Bluetooth Features | 18 | | 1.2.5 Wireless Audio Features | 18 | | 1.2.6 Concurrent Mode Feature | | | 1.3 Typical Applications | 18 | | 1.4 Ordering Information | 19 | | 1.5 Package | 19 | | 1.6 Pin Layout | 23 | | 2 Key Electrical Specifications | 32 | | 2.1 Absolute Maximum Rating | 32 | | 2.2 Recommended Operating Conditions | 32 | | 2.3 DC Characteristics | 32 | | 2.4 AC Characteristics | 33 | | 2.5 Analog Input to Digital Output | 43 | | 2.6 Digital Input to Analog Output | 44 | | 2.7 MICBIAS Characteristics | 45 | | 2.8 Digital Microphone Interface Characteristics | 46 | | 2.9 Storage Condition | 47 | | 3 Reference Design | 48 | | 3.1 Schematic | 48 | | 3.2 BOM (Bill of Material) | 49 | | 4 Memory, MCU and PMU | 52 | | 4.1 Memory | 52 | | 4.1.1 SRAM | 52 | | 4.1.2 Flash | 53 | | 4.1.3 E-Fuse | 53 | | 4.1.4 Unique ID | 54 | | 4.2 MCU | 54 | | | 4.3 Working Mode | 54 | |-----|------------------------------------------------------|----| | | 4.4 Reset | 57 | | | 4.5 Power Management | 58 | | | 4.5.1 Power-on-Reset (POR) and Brown-out Detect | 58 | | | 4.5.2 Working Mode Switch | 62 | | | 4.5.3 LDO and DCDC | 63 | | | 4.5.4 VBAT and VANT Power-Supply Mode | 64 | | | 4.6 Charger | 64 | | | 4.7 Wakeup Source | 66 | | 5 . | Audio | 69 | | | 5.1 Audio CODEC | 69 | | | 5.2 Audio-in Path | 69 | | | 5.3 Audio-out Path | 70 | | | 5.4 Register Description | 70 | | 6 | BT/BLE RF Transceiver | 75 | | | 6.1 Overview | 75 | | | 6.2 Air Interface Data Rate and RF Channel Frequency | 75 | | | 6.3 Baseband | 76 | | | 6.3.1 Packet Format | 76 | | | 6.3.2 BLE Location Function | 77 | | | 6.3.3 RSSI and Frequency Offset | 77 | | 7 | Clock | 78 | | | 7.1 Clock Sources | 78 | | | 7.2 System Clock | 80 | | | 7.3 Module Clock | 80 | | | 7.3.1 System Timer Clock | 80 | | | 7.3.2 USB Clock | 80 | | | 7.3.3 DMIC Clock | 80 | | | 7.3.4 clkzb32k | 80 | | | 7.3.5 clk_7816 | | | | 7.3.6 clk_eoc_src | | | | 7.3.7 clk_zb_mst | | | | 7.3.8 clk_mspi | | | | 7.4 Register Table | | | 8 | Timer | 84 | | 8.1 Timer0 ~ Timer1 | 84 | |-----------------------------------------------------------------|-----| | 8.1.1 Mode O (System Clock Mode) | 84 | | 8.1.2 Mode 1 (GPIO Trigger Mode) | 84 | | 8.1.3 Mode 2 (GPIO Pulse Width Mode) | 85 | | 8.1.4 Mode 3 (Tick Mode) | 86 | | 8.1.5 Watchdog | 86 | | 8.1.6 Register Table | 87 | | 8.2 32K LTimer | 89 | | 8.3 System Timer | 89 | | 9 Interrupt System | 90 | | 9.1 Interrupt Structure | 90 | | 9.2 External Interrupt Sources | 91 | | 9.3 Register Description | 93 | | 10 Interface | 97 | | 10.1 GPIO | 97 | | 10.1.1 Basic Configuration | 97 | | 10.1.2 Connection Relationship between GPIO and Related Modules | 103 | | 10.1.3 Drive Strength | 104 | | 10.1.4 Polarity | 104 | | 10.1.5 GPIO IRQ Signal | 104 | | 10.1.6 GPIO2RISC IRQ Signal | 105 | | 10.1.7 Pull-up/Pull-down Resistors | 106 | | 10.2 Swire | 108 | | 10.3 I2C | 109 | | 10.3.1 Communication Protocol | 109 | | 10.3.2 I2C Slave Mode | 109 | | 10.3.3 I2C Master Mode | 110 | | 10.3.3.1 I2C Master Write Transfer in NDMA Mode | 111 | | 10.3.3.2 I2C Master Read Transfer in NDMA Mode | 111 | | 10.3.3.3 I2C Master Writer Transfer in NDMA Mode | 111 | | 10.3.3.4 I2C Master Read Transfer in NDMA Mode | 111 | | 10.3.4 Register Description | 111 | | 10.4 Memory SPI | 114 | | 10.4.1 Memory SPI Diagram | 114 | | 10.4.2 Register Description | 114 | | 10.5 HSPI | 115 | | | 10.5.1 Diagram | 115 | |----|--------------------------------------------------|-----| | | 10.5.2 Features | 116 | | | 10.5.3 Function Description | 116 | | | 10.5.3.1 Master Mode | 116 | | | 10.5.3.2 Slave Mode | 117 | | | 10.5.3.3 Dual, Quad and 3line I/O | 118 | | | 10.5.3.4 XIP | 118 | | | 10.5.3.5 LCD Display Driving | 118 | | | 10.6 PSPI | 122 | | | 10.6.1 Diagram | 122 | | | 10.6.2 Features | 122 | | | 10.6.3 Function Descriptions | 122 | | | 10.7 SPI Slave (SPI_SLV) | 124 | | | 10.7.1 Diagram | 124 | | | 10.7.2 Features | 124 | | | 10.7.3 Function Description | 124 | | | 10.8 UART | 125 | | | 10.9 USB | 128 | | 11 | PWM | 135 | | | 11.1 Enable PWM | 135 | | | 11.2 Set PWM Clock | 135 | | | 11.3 PWM Waveform, Polarity and Output Inversion | 135 | | | 11.3.1 Waveform of Signal Frame | 135 | | | 11.3.2 Invert PWM Output | 136 | | | 11.3.3 Polarity for Signal Frame | 136 | | | 11.4 PWM Mode | 136 | | | 11.4.1 Select PWM Modes | 136 | | | 11.4.2 Continuous Mode | 136 | | | 11.4.3 Counting Mode | 137 | | | 11.4.4 IR Mode | 137 | | | 11.4.5 IR FIFO Mode | 138 | | | 11.4.6 IR DMA FIFO Mode | 139 | | | 11.5 PWM Interrupt | 140 | | | 11.6 Register Description | 140 | | 12 | Manchester Decoder(MDEC) | 145 | | | 12.1 Frame Format | 145 | | 12.2 Function Description | 145 | |--------------------------------------------------|-----| | 12.2.1 Block Diagram | 145 | | 12.2.2 Reset MDEC | 146 | | 12.2.3 Select Input Channel | 146 | | 12.2.4 Read Result Data | 146 | | 12.3 Register Description | 146 | | 13 SAR ADC | 148 | | 13.1 Power On/Down | 148 | | 13.2 ADC Clock | 148 | | 13.3 ADC Control in Auto Mode | 148 | | 13.3.1 Set Max State and Enable Channel | 148 | | 13.3.2 "Set" State | 149 | | 13.3.3 "Capture" State | 149 | | 13.3.4 Usage Case with Detailed Register Setting | | | 13.4 Battery Voltage Sampling | 151 | | 13.5 Register Table | 151 | | 14 Temperature Sensor | 156 | | 15 Low Power Comparator | 157 | | 15.1 Power On/Down | 157 | | 15.2 Select Input Channel | 157 | | 15.3 Select Mode and Input Channel for Reference | 157 | | 15.4 Select Scaling Coefficient | 158 | | 15.5 Low Power Comparator Output | 158 | | 15.6 Register Description | 158 | | 16 AES | 160 | | 17 Public Key Engine (PKE) | 161 | | 17.1 Calculation Model Overview | 161 | | 17.2 Function Description | 161 | | 17.2.1 Module Description | 161 | | 17.2.2 Software Interface (Programming Model) | 162 | | 17.3 Register Description | 164 | | 18 True Random Number Generator (TRNG) | 167 | | 18.1 Model Overview | 167 | | 18.2 Interrupt Description | 167 | | 18.2.1 CPU Reads RBG_DR without Data | 167 | | 18.2.2 Data Valid | 168 | |---------------------------|-----| | 18.3 Usage Procedure | 168 | | 18.3.1 Normal Operation | 168 | | 18.3.2 Entropy Source | 168 | | 18.4 Register Description | 168 | # List of Figures | Figure 1-1 Block Diagram of the System | 15 | |-----------------------------------------------------------------|-----| | Figure 1-2 Package of TLSR9515A/B | 20 | | Figure 1-3 Package of TLSR9515D | 22 | | Figure 1-4 Pin Assignment for TLSR9515A/B | 24 | | Figure 1-5 Pin Assignment of TLSR9515D | 27 | | Figure 3-1 Schematic of TLSR9515A | 48 | | Figure 3-2 Schematic of TLSR9515B | 48 | | Figure 3-3 Schematic of TLSR9515D | 49 | | Figure 3-4 BOM Table of TLSR9515B | 50 | | Figure 4-1 Memory Map | 53 | | Figure 4-2 Control Logic of Power up/down | 58 | | Figure 4-3 Initial Power-up Sequence | 60 | | Figure 4-4 Initial Power-down Sequence | 61 | | Figure 4-5 LDO and DCDC | 63 | | Figure 4-6 Charger Diagram | 64 | | Figure 4-7 Charging Timing Diagram | 65 | | Figure 4-8 Wake up Sources | 66 | | Figure 5-1 Audio CODEC | 69 | | Figure 5-2 Audio in Path | 70 | | Figure 5-3 Audio out Path | 70 | | Figure 6-1 Block Diagram of RF Transceiver | 75 | | Figure 7-1 Clock Source | 78 | | Figure 9-1 Block Diagram of PLIC | 90 | | Figure 10-1 Logic Relationship between GPIO and Related Modules | 104 | | Figure 10-2 I2C Timing | 109 | | Figure 10-3 Byte Consisted of Slave Address and R/W Flag Bit | 110 | | Figure 10-4 Read Format in Slave Mode | 110 | | Figure 10-5 Write Format in Slave Mode | 110 | |------------------------------------------|-----| | Figure 10-6 Memory SPI Diagram | 114 | | Figure 10-7 HSPI Diagram | 116 | | Figure 10-8 Master Transfer Mode Format | 117 | | Figure 10-9 Slave Transfer Mode Format | 117 | | Figure 10-10 3-Line Write Sequence | 119 | | Figure 10-11 3-Line Read Sequence | 119 | | Figure 10-12 4-Line Write Sequence | 119 | | Figure 10-13 4-Line Read Sequence | 120 | | Figure 10-14 2-Line Write Sequence | 120 | | Figure 10-15 RGB565 Pixel Transition | 121 | | Figure 10-16 RGB666 Pixel Transition | 121 | | Figure 10-17 RGB888 Pixel Transition | 121 | | Figure 10-18 PSPI Diagram | 122 | | Figure 10-19 PSPI Master Transfer Format | 123 | | Figure 10-20 Slave Transfer Mode Format | 123 | | Figure 10-21 SPI_SLV Diagram | 124 | | Figure 10-22 SPI_SLV Write Format | 125 | | Figure 10-23 SPI_SLV Read Format | 125 | | Figure 10-24 UART Communication | 126 | | Figure 11-1 Signal Frame | 135 | | Figure 11-2 PWM Output Waveform Chart | 136 | | Figure 11-3 Continuous Mode | 137 | | Figure 11-4 Counting Mode (n=0) | 137 | | Figure 11-5 IR Mode (n=0) | 138 | | Figure 11-6 IR Format Examples | 139 | | Figure 12-1 Frame Format | 145 | | Figure 12-2 MDEC Function Block Diagram | 145 | | Figure 13-1 Diagram of ADC | 148 | | Figure 14-1 Block Diagram of Temperature Sensor | . 156 | |---------------------------------------------------|-------| | Figure 15-1 Block Diagram of Low Power Comparator | . 157 | | Figure 16-1 AES Address | . 160 | | Figure 17-1 Block Diagram of PKE SP Module | . 162 | | Figure 18-1 Module Boundary | . 167 | # List of Tables | Table 1-1 Ordering Information of TLSR9515 | . 19 | |------------------------------------------------------------------------------|------| | Table 1-2 Mechanical Dimension for TLSR9515A/B | 20 | | Table 1-3 Mechanical Dimension of TLSR9515D | . 22 | | Table 1-4 Pin Function of TLSR9515A/B | . 24 | | Table 1-5 GPIO Pin Mux of TLSR9515A/B | . 26 | | Table 1-6 Pin Functions of TLSR9515D | . 27 | | Table 1-7 GPIO Pin Mux of TLSR9515D | . 29 | | Table 1-8 Flash IO Pin Mux | . 31 | | Table 2-1 Absolute Maximum Rating | . 32 | | Table 2-2 Recommended Operating Conditions | . 32 | | Table 2-3 DC Characteristics(VBAT=4.2 V, T = 25 °C ) | . 32 | | Table 2-4 Digital Inputs/Outputs AC Characteristics (VDD = 3.3 V, T = 25 °C) | . 33 | | Table 2-5 RF Performance AC Characteristics(VBAT = 4.2 V, T = 25 °C ) | . 34 | | Table 2-6 USB Characteristics | . 41 | | Table 2-7 RSSI Characteristics | . 42 | | Table 2-8 24MHz Crystal Characteristics | . 42 | | Table 2-9 32.768 kHz Crystal Characteristics | . 42 | | Table 2-10 24 MHz RC Oscillator Characteristics | . 42 | | Table 2-11 32 kHz RC Oscillator Characteristics | . 42 | | Table 2-12 ADC Characteristics | . 43 | | Table 2-13 Analog Microphone / Line Input to ADC Path | . 43 | | Table 2-14 Audio DAC to Headphone Output Path | . 44 | | Table 2-15 MICBIAS Characteristics | . 46 | | Table 2-16 Digital Microphone Interface Characteristics | . 46 | | Table 3-1 BOM Table of TLSR9515A | . 49 | | Table 3-2 BOM of TLSR9515D | 50 | | Table 4-1 E-Fuse Information | . 53 | 12 | Table 4-2 Working Mode | 54 | |--------------------------------------------------------------------|-----| | Table 4-3 Retention Analog Registers in Deep Sleep | 56 | | Table 4-4 Register Configuration for Software Reset | 57 | | Table 4-5 Analog Register to Control Delay Counters | 59 | | Table 4-6 Characteristics of Initial Power-up/Power-down Sequence | 61 | | Table 4-7 3.3 V Analog Register for Module Power up/down Control | 62 | | Table 4-8 Analog Register for Wakeup | 67 | | Table 5-1 Audio Registers | 71 | | Table 6-1 Packet Format in Standard 1 Mbps BLE Mode | 76 | | Table 6-2 Packet Format in Standard 2 Mbps BLE Mode | 76 | | Table 6-3 Packet Format in Standard 500 kbps/125 kbps BLE Mode | 76 | | Table 6-4 Packet Format of Basic Rate Packets | 76 | | Table 6-5 Packet Format of Enhanced Data Rate Packet | 77 | | Table 7-1 Clock Sources of Each Module | 79 | | Table 7-2 Clock Related Registers | 81 | | Table 8-1 Register Configuration for Timer 0 ~ Timer 1 | 87 | | Table 8-2 Register Table for System Timer | 89 | | Table 9-1 Interrupt Sources | 91 | | Table 9-2 Register Configuration for PLIC | 93 | | Table 10-1 GPIO Pad Function Mux | 97 | | Table 10-2 GPIO Setting | 99 | | Table 10-3 GPIO Function Mux Configuration Registers | 102 | | Table 10-4 GPIO IRQ Table | 105 | | Table 10-5 Analog Registers for Pull-up/Pull-down Resistor Control | 106 | | Table 10-6 SWIRE Related Registers | 108 | | Table 10-7 I2C Related Registers | 111 | | Table 10-8 Memory SPI Register Description | 115 | | Table 10-9 Slave Commands | 117 | | Table 10-10 Slave Commands | 123 | | Table 10-11 SPI_SLV Commands | 125 | |------------------------------------------------------------|-----| | Table 10-12 UARTO Related Registers | 126 | | Table 10-13 USB Related Registers | 129 | | Table 11-1 PWM Registers | 140 | | Table 12-1 MDEC Related Registers | 147 | | Table 13-1 Overall Register Setting | 150 | | Table 13-2 SAR ADC Registers | 151 | | Table 14-1 Analog Register for Temperature Sensor | 156 | | Table 15-1 Analog Register Related to Low Power Comparator | 158 | | Table 16-1 AES Registers | 160 | | Table 17-1 Dual Port Ram Address Map | 163 | | Table 17-2 PKE Related Registers | 164 | | Table 18-1 Register Description | 169 | ### 1 Overview The TLSR9515 supports standards and industrial alliance specifications including Bluetooth 5.2, Basic data rate (BR), Enhanced data rate (EDR), LE, indoor positioning and BLE Mesh standard. The TLSR9515 combines the features and functions needed for high quality wireless audio equipments into a single SoC. ## 1.1 Block Diagram The TLSR9515 is designed to offer high integration, ultra-low power application capabilities. The system's block diagram is as shown in Figure 1-1. Figure 1-1 Block Diagram of the System - \*: applicable only for TLSR9515D - \*\*: applicable only for TLSR9515A and TLSR9515B - \*\*\*: applicable for TLSR9515D - \*\*\*\*: applicable only for TLSR9515D The TLSR9515 integrates a powerful 32-bit RISC-V (RISC-Five) MCU, DSP, 2.4 GHz ISM Radio, 256 KB SRAM, 1 MB(TLSR9515A)/512 KB(TLSR9515B) Flash, or external Flash(TLSR9515D), stereo/Mono audio codec,14 bit AUX DS-TLSR9515-E5 15 Ver 0.8.4 ADC, analog and digital Microphone input, PWM, flexible IO interfaces, and other peripheral blocks required for advanced audio applications. The TLSR9515 also includes multi-stage power management design allowing ultra-low power operation and making it the ideal candidate for wearable and power-constraint applications. With the high integration level of TLSR9515, few external components are needed to satisfy customers' ultralow cost requirements. ## 1.2 Key Features ### 1.2.1 General Features General features are as follows: - 1. Support unique ID (UID) - 2. 32-bit RISC-V micro-controller - · Better power-balanced performance than ARM M4 - · Instruction and Data cache controller - Maximum running speed up to 96 MHz - Integrated DSP extensions instructions - Integrated "F" standard extensions for single-precision floating-point - 3. Memory architecture - · Program memory: up to 1 MB Flash or 16 MB external Flash - Up to 256 KB SRAM including up to 64 KB retention SRAM - 4. RTC and other timers - Clock source: 24 MHz/32.768 kHz Crystal and 32 kHz/24 MHz embedded RC oscillator - · Three general 32-bit timers with four selectable modes in active mode - Watchdog timer - A low-frequency 32 kHz timer available in low power mode - 5. A rich set of digital and analog interfaces - Up to 27 GPIOs(TLSR9515D) or 15 GPIOs(TLSR9515A/B) - Configurable to select 2-wire SDP or 5-wire JTAG debug interface - Dual DMIC (Digital Mic)<sup>1</sup> - Support AMIC (Analog Mic), 24 bit 192 kHz I2S - Stereo audio codec - SPI, I2C, USB 2.0, Swire, UART with hardware flow control and 7816 protocol support<sup>2</sup> - Up to 6 channels of differential PWM - IR transmitter with DMA - 2-channel (only GPIO input), 14-bit Auxiliary ADC - Low power comparator - 1. Applicable for TLSR9515A and TLSR9515D - 2. Applicable only for TLSR9515D DS-TLSR9515-E5 16 Ver 0.8.4 - 6. Embedded hardware AES and AES-CCM - 7. Embedded hardware acceleration for Elliptical curve cryptography (ECC) - 8. Embedded Random Number Generator (TRNG) - Hardware OTA upgrade and multiple boot switch, allowing convenient product feature roll outs and upgrades - 10. Operating temperature range: -40°C~+85°C - 11. Completely RoHS-compliant package - TLSR9515A/B, 40-pin QFN 4x6mm - TLSR9515D, 56-pin QFN 7x7mm - 12. Supports Bluetooth 5.2, BLE Mesh ### 1.2.2 RF Features RF features include: - 1. Bluetooth RF transceiver in worldwide 2.4 GHz ISM band - Bluetooth Compliant, BR, EDR 2 Mbps and 3 Mbps,BLE 1 Mbps and 2 Mbps, Long Range 125 kbps and 500 kbps,250 kbps - 3. Rx Sensitivity: -92 dBm @ BR mode, -92.5 dBm @ EDR 2 Mbps mode, -86 dBm @ EDR 3 Mbps mode, -96 dBm@BLE 1 Mbps, -92.5 dBm @ BLE 2 Mbps mode, -99.5 dBm @ Long Range 125 kbps, -98.5 dBm @ Long Range 500 kbps, - 4. Tx output power: up to +10 dBm @ BR/BLE mode, +1.5 dBm @ EDR mode - 5. 50 $\Omega$ matched single-pin antenna input - 6. RSSI monitoring with +/-1 dB resolution - 7. Auto acknowledgment, retransmission and flow control - 8. Support full-function BLE AoA/AoD location features<sup>1</sup> - 9. Support PTA (Packet Traffic Arbitrator) for Wi-Fi co-existence ### 1.2.3 Features of Power Management Module Features of power management module include: - 1. Power supply - VBAT (battery): 1.8 V~4.3 V - VBUS (USB): 4.5 V~5.5 V - 2. Battery monitor for low battery voltage detection - 3. Brownout detection/shutoff and Power-On-Reset - 4. Multiple-power-state to optimize power consumption - 5. Supports USB BC1.2 Battery Charging - 6. Power consumption: - Whole Chip, RX EDR mode: 5 mA @ 4.2 V DCDC, 11.5 mA with LDO - Whole Chip, TX EDR mode: 13 mA @ 0 dBm, 4.2 V DCDC, TBD with LDO DS-TLSR9515-E5 17 Ver 0.8.4 <sup>1.</sup> Applicable only for TLSR9515D - Whole Chip, BLE RX mode: 5 mA @ 4.2 V DCDC, 11.5 mA with LDO - Whole Chip, BLE TX mode, 5.5 mA @ 0 dBm, 4.2V DCDC, 12.5 mA @ 0 dBm with LDO - Deep sleep with external wakeup (without SRAM retention): 0.7 μA - Deep sleep with 32K SRAM retention: 1.7 μA #### 1.2.4 Bluetooth Features Bluetooth features include: - 1. Bluetooth support with BR, EDR, and BLE - 2. Long range support with 125 kbps and 500 kbps data rate - 3. Bluetooth SIG Mesh support - 4. Bluetooth based location and indoor positioning support with AoA and AoD (a.k.a Bluetooth 5.1)<sup>1</sup> - 5. Bluetooth ISO channel support (a.k.a Bluetooth 5.2) with broadcast and unicast mode ### 1.2.5 Wireless Audio Features Wireless audio features include: - 1. High performance Stereo Audio Codec with SNR over 96dB and sampling rate up to 192 kHz - 2. 24-bit ADC/DAC for Codec - 3. Telink-patented technology for true wireless stereo and 1+N hearable devices with synchronized playback and balanced power on all devices - 4. Support audio codec for SBC, OPUS, LC3 - 5. Support voice codec such as G.711, A-Law, u-Law, CVSD, mSBC - 6. Support HFP 1.7, HSP 1.2, A2DP 1.3, AVRCP 1.6, SPP 1.2, and PBAP 1.0, ANCS, DIS - 7. Support Apple iAP2 - 8. Support EDR+BLE dual mode operation - 9. Support noise suppression and echo cancellation - 10. Support Packet Loss Concealment (PLC) for voice processing ### 1.2.6 Concurrent Mode Feature In concurrent mode, the chip supports multiple standards working concurrently. ## 1.3 Typical Applications The TLSR9515 is an ideal SoC for advanced wireless audio solutions. Its typical applications include, but are not limited to the following: - Wearable devices - Augmented reality glasses - Smart watches - Smart trackers DS-TLSR9515-E5 18 Ver 0.8.4 <sup>1.</sup> Applicable only for TLSR9515D - ° Wristband - Audio Solutions - ° Wireless headsets - ° Earbuds # 1.4 Ordering Information Table 1-1 Ordering Information of TLSR9515 | Product Series | Package Type | Temperature<br>Range | Ordering No. | Packing<br>Method | Minimum<br>Order<br>Quantity | |----------------|----------------------|----------------------|--------------|-------------------|------------------------------| | TLSR9515 | QFN40,<br>4x6x0.75mm | -40°C~+85°C | TLSR9515AER | TR | 3000 | | | QFN40,<br>4x6x0.75mm | -40°C~+85°C | TLSR9515BER | TR | 3000 | | | QFN56,<br>7x7x0.75mm | -40°C~+85°C | TLSR9515DER | TR | 3000 | # 1.5 Package Package dimensions of TLSR9515 are shown below. Table 1-2 Mechanical Dimension for TLSR9515A/B | SYMBOL | MILLIMETER | | | | | |---------|------------|---------|------|--|--| | STRIBUL | MIN | NOM | MAX | | | | Α | 0.70 | 0.75 | 0.80 | | | | A1 | - | 0.02 | 0.05 | | | | A2 | - | 0.55 | - | | | | А3 | 0.203 REF | | | | | | ь | 0.15 0.20 | | 0.25 | | | | D | 6 BSC | | | | | | E | 4 BSC | | | | | | е | | 0.4 BSC | | | | | CVMPOL | MILLIMETER | | | | | | |--------|------------|-----|-----|--|--|--| | SYMBOL | MIN | NOM | MAX | | | | | D2 | 4.7 | 4.8 | 4.9 | | | | | E2 | 2.7 | 2.8 | 2.9 | | | | | L | 0.2 | 0.3 | 0.4 | | | | | К | 0.3 REF | | | | | | | 999 | 0.1 | | | | | | | ссс | 0.1 | | | | | | | eee | 0.08 | | | | | | | bbb | 0.07 | | | | | | | fff | 0.1 | | | | | | Table 1-3 Mechanical Dimension of TLSR9515D | SYMBOL | MILLIMETER | | | | | | |---------|------------|------|------|--|--|--| | STIMBUL | MIN | NOM | MAX | | | | | А | 0.70 | 0.75 | 0.80 | | | | | A1 | 0 | 0.02 | 0.05 | | | | | A2 | - | 0.55 | - | | | | | b | 0.15 | 0.20 | 0.25 | | | | | D | 7 BSC | | | | | | | Е | 7 BSC | | | | | | | SYMBOL | MILLIMETER | | | | | |---------|------------|---------|------|--|--| | STIMBOL | MIN | NOM | MAX | | | | е | | 0.4 BSC | | | | | D2 | 5.10 | 5.20 | 5.30 | | | | E2 | 5.10 | 5.20 | 5.30 | | | | L | 0.30 | 0.40 | 0.50 | | | | К | 0.5 REF | | | | | | 999 | 0.1 | | | | | | ссс | 0.1 | | | | | | eee | 0.08 | | | | | | bbb | 0.07 | | | | | | fff | | 0.1 | | | | # 1.6 Pin Layout Pin assignment of TLSR9515A/B is shown below. VLINE\_PAD GANT PA[3] PA[2] PA[1] PE[7] PE[6] PE[2] PE[0] ANT40 39 38 37 36 35 34 33 32 31 30 29 1 28 RESETB PA[7] PB[2] 2 27 AVDD3 3 26 PB[3] VDD1V8\_O TLSR9515A/ PB[4] 4 25 FVDD1V8 TLSR9515B VDD1V4 PB[6] 5 24 23 VDD1V4\_O AIPL1 6 AIPR1 7 22 VDD3 MICBIAS1 8 21 VBAT 10 11 12 13 14 15 16 17 18 19 20 VCAP AONHPR AOPHPR VBUS AVD PC[0] PC[1] PC[2] VREFP\_CODEC AOPHPL AONHPL VDDDEC Figure 1-4 Pin Assignment for TLSR9515A/B Functions of 40 pins for TLSR9515A/B are described in table below: Table 1-4 Pin Function of TLSR9515A/B | NO. | Pin Name | Туре | Description | |-----|--------------------------------------------|----------|---------------------------------------------------------| | 1 | PA[7] | GPIO | GPIO PA[7] | | 2 | PB[2] | GPIO | GPIOPB[2] | | 3 | PB[3] | GPIO | GPIOPB[3] | | 4 | PB[4] | GPIO | GPIOPB[4] | | 5 | PB[6] | GPIO | GPIO PB[6] | | 6 | AIPL1 | Analog | Left channel single-ended or positive analog input 1 | | 7 | AIPR1<br>(TLSR9515A)/<br>NC<br>(TLSR9515B) | Analog/- | Right channel single-ended or positive analog input 1/- | | 8 | MICBIAS1 | Analog | Microphone biasing voltage | | NO. | Pin Name | Туре | Description | |-----|-----------------|--------|-------------------------------------------------------------------------------------------------------| | 9 | VCAP | Analog | Decoupling cap for internal biasing voltage for internal circuits. This signal is an output of the IC | | 10 | VREFP_CODE<br>C | Analog | Analog positive supply and reference for internal circuit. This signal is an output of the IC | | 11 | AVD | PWR | Analog positive power supply for embedded linear regulator | | 12 | AOPHPL | Analog | Left channel positive headphone output | | 13 | AONHPL | Analog | Left channel negative headphone output | | 14 | AONHPR | Analog | Right channel negative headphone output | | 15 | AOPHPR | Analog | Right channel positive headphone output | | 16 | PC[0] | GPIO | GPIO PC[0] | | 17 | PC[1] | GPIO | GPIO PC[1] | | 18 | PC[2] | GPIO | GPIO PC[2] | | 19 | VDDDEC | PWR | 1.2V output of digital Ido | | 20 | VBUS | PWR | 5V VBUS power supply of USB | | 21 | VBAT | PWR | Lion-Battery power supply | | 22 | VDD3 | PWR | 3.3 V power supply | | 23 | VDD1V4_O | PWR | 1.4V output of DCDC | | 24 | VDD1V4 | PWR | 1.4V power supply of digital | | 25 | FVDD1V8 | PWR | 1.8V power supply of flash memory | | 26 | VDD1V8_O | PWR | 1.8V output of DCDC | | 27 | AVDD3 | PWR | 3.3V power supply of DCDC | | 28 | RESETB | Reset | Power on reset, active low | | 29 | GANT | Analog | GND of RF | | 30 | ANT | Analog | Pin to connect to the Antenna through the matching network | | 31 | VLINE_PAD | PWR | 1.4V power supply of RF Transceiver | | 32 | XC1 | Analog | Crystal oscillator pin | | 33 | XC2 | Analog | Crystal oscillator pin | | 34 | PE[0] | GPIO | GPIO PE[0] | | 35 | PE[2] | GPIO | GPIO PE[2] | | NO. | Pin Name | Туре | Description | |-----|----------|------|-------------| | 36 | PE[6] | GPIO | GPIO PE[6] | | 37 | PE[7] | GPIO | GPIO PE[7] | | 38 | PA[1] | GPIO | GPIO PA[1] | | 39 | PA[2] | GPIO | GPIO PA[2] | | 40 | PA[3] | GPIO | GPIO PA[3] | GPIO multiple functions of TLSR9515A/B are listed in table below: Table 1-5 GPIO Pin Mux of TLSR9515A/B | Pad | Default | Func1 | Func2 | Func3 | Func4 | Analog Func | |-------|------------|------------------|----------------------------|--------------|-----------------------------|--------------------------| | PA[1] | SPI_SLV_CN | HSPI_CN_IO | DAC_I_DATO_I | UARTO_CTS_I | SPI_SLV_CN_I | - | | PA[2] | SPI_SLV_CK | HSPI_CK_IO | DAC_Q_DATO_I | UARTO_RTS | SPI_SLV_CK_I | - | | PA[3] | SPI_SLV_DI | HSPI_MISO_I<br>O | ADC_I_DAT2 | UARTO_TX | SPI_SLV_DI_IO | - | | PA[7] | SWS_IO | - | - | - | SWS_IO | - | | PB[2] | GPIO | TX_DATO_I | UARTO_TX/<br>DAC_I_DAT2_I | I2C_SCK_IO | DMIC_DAT_I/<br>HSPI_MISO_IO | lp_comp<2>/<br>sar_in<2> | | PB[3] | GPIO | TX_DAT1_I | UARTO_RTX_IO /DAC_I_DAT3_I | I2C_SDA_IO | DMIC_CLK1HS PI_MOSI_IO | Ip_comp<3>/<br>sar_in<3> | | PB[4] | GPIO | TX_DAT2_I | UARTO_RTS/<br>DAC_I_DAT4_I | PWM0 | DMIC_CLK2_O<br>HSPI_CK_IO | Ip_comp<4>/<br>sar_in<4> | | PB[6] | GPIO | RATEO_I | UARTO_CTS_I/ DAC_I_DAT6_I | PSPI_MISO_IO | TX_CYC2PA_O<br>/HSPI_CN_IO | lp_comp<6>/<br>sar_in<6> | | PC[0] | GPIO | PWM0 | RX_EN_I | PSPI_CN_IO | SWM_IO | - | | PC[1] | GPIO | DMIC_DAT_I | TX_CLK_I | ATSEL[0] | I2C_SCK_IO | - | | PC[2] | GPIO | ADC_I_DATO | DMIC_CLK1/<br>DAC_Q_DAT2_I | ATSEL[1] | I2C_SDA_IO | - | | PE[0] | GPIO | PWM3 | FREQ_CHN_I | UART1_TX | I2C_SCK_IO | - | | PE[2] | GPIO | PWM2 | ADC_Q_DAT4 | UART1_RTX_IO | I2C_SDA_IO | - | | PE[6] | TMS | - | ADC_Q_DAT8 | PWM2_N | TMS_IO | - | | PE[7] | TCK | - | ADC_Q_DAT9 | PWM3_N | TCK_I | - | Pin assignment of TLSR9515D is shown as below. Figure 1-5 Pin Assignment of TLSR9515D VLINE\_PAD PA[0] PE[7] PE[6] PE[5] PE[0] GANT PA[1] PE[4] PE[3] PE[2] ANT XC1 56 55 53 51 48 47 46 45 44 43 54 52 50 49 1 42 RESETB PA[5] PA[6] 2 PD[3] 41 PA[7] 3 40 PD[2] PB[0] 4 39 PD[1] PB[1] 5 38 PD[0] PB[2] 6 37 AVDD3 **TLSR9515D** 7 PB[3] VDD1V8\_O PF[0] 8 35 FVDD1V8 PF[1] 9 34 PF[5] 10 33 PF[4] PF[2] PB[4] 11 32 PF[3] PB[6] 12 31 VDD1V4 13 PB[7] VDD1V4\_O 30 14 AIPL1 29 VDD3 16 21 26 18 19 20 22 23 24 27 28 MICBIAS1 VCAP VSSA VDDDEC VBUS AVD AOPHPL AONHPL PC[0] PC[1] VREFP\_CODEC VBAT Functions of the 56 pins of TLSR9515D are shown in table below. Table 1-6 Pin Functions of TLSR9515D | NO. | Pin Name | Туре | Description | |-----|----------|------|-------------| | 1 | PA[5] | GPIO | GPIO PA[5] | | 2 | PA[6] | GPIO | GPIO PA[6] | | 3 | PA[7] | GPIO | GPIO PA[7] | | 4 | PB[O] | GPIO | GPIOPB[0] | | 5 | PB[1] | GPIO | GPIOPB[1] | | 6 | PB[2] | GPIO | GPIOPB[2] | | NO. | Pin Name | Туре | Description | |-----|------------|--------|-------------------------------------------------------------------------------------------------------| | 7 | PB[3] | GPIO | GPIOPB[3] | | 8 | PF[O] | GPIO | GPIOPF[0] | | 9 | PF[1] | GPIO | GPIOPF[1] | | 10 | PF[2] | GPIO | GPIOPF[2] | | 11 | PB[4] | GPIO | GPIOPB[4] | | 12 | PB[6] | GPIO | GPIO PB[6] | | 13 | PB[7] | GPIO | GPIO PB[7] | | 14 | AIPL1 | Analog | Left channel single-ended or positive analog input 1 | | 15 | MICBIAS1 | Analog | Microphone biasing voltage | | 16 | VCAP | Analog | Decoupling cap for internal biasing voltage for internal circuits. This signal is an output of the IC | | 17 | VSSA | GND | Analog negative power supply for internal circuit | | 18 | VREFP_CODE | Analog | Analog positive supply and reference for internal circuit. This signal is an output of the IC | | 19 | AVD | PWR | Analog positive power supply for embedded linear regulator | | 20 | AOPHPL | Analog | Left channel positive headphone output | | 21 | AONHPL | Analog | Left channel negative headphone output | | 22 | PC[0] | GPIO | GPIO PC[0] | | 23 | PC[1] | GPIO | GPIO PC[1] | | 24 | PC[2] | GPIO | GPIO PC[2] | | 25 | PC[3] | GPIO | GPIO PC[3] | | 26 | VDDDEC | PWR | 1.2V output of digital Ido | | 27 | VBUS | PWR | 5V VBUS power supply of USB | | 28 | VBAT | PWR | Lion-Battery power supply | | 29 | VDD3 | PWR | 3.3 V power supply | | 30 | VDD1V4_O | PWR | 1.4V output of DCDC | | 31 | VDD1V4 | PWR | 1.4V power supply of digital | | 32 | PF[3] | GPIO | GPIOPF[3] | | 33 | PF[4] | GPIO | GPIOPF[4] | | NO. | Pin Name | Туре | Description | |-----|-----------|--------|------------------------------------------------------------| | 34 | PF[5] | GPIO | GPIOPF[5] | | 35 | FVDD1V8 | PWR | 1.8V power supply of flash memory | | 36 | VDD1V8_O | PWR | 1.8V output of DCDC | | 37 | AVDD3 | PWR | 3.3V power supply of DCDC | | 38 | PD[O] | GPIO | GPIO PD[0] | | 39 | PD[1] | GPIO | GPIO PD[1] | | 40 | PD[2] | GPIO | GPIO PD[2] | | 41 | PD[3] | GPIO | GPIO PD[3] | | 42 | RESETB | Reset | Power on reset, active low | | 43 | GANT | Analog | GND of RF | | 44 | ANT | Analog | Pin to connect to the Antenna through the matching network | | 45 | VLINE_PAD | PWR | 1.4V power supply of RF Transceiver | | 46 | XC1 | Analog | Crystal oscillator pin | | 47 | XC2 | Analog | Crystal oscillator pin | | 48 | PE[0] | GPIO | GPIO PE[0] | | 49 | PE[2] | GPIO | GPIO PE[2] | | 50 | PE[3] | GPIO | GPIO PE[3] | | 51 | PE[4] | GPIO | GPIO PE[4] | | 52 | PE[5] | GPIO | GPIO PE[5] | | 53 | PE[6] | GPIO | GPIO PE[6] | | 54 | PE[7] | GPIO | GPIO PE[7] | | 55 | PA[0] | GPIO | GPIO PA[0] | | 56 | PA[1] | GPIO | GPIO PA[1] | GPIO multiple functions of TLSR9515D are listed in table below: ### Table 1-7 GPIO Pin Mux of TLSR9515D | Pad | Default | Func1 Func2 | | Func3 | Func4 | Analog Func | |-------|------------|-------------|--------------|-------------|--------------|-------------| | PA[0] | GPIO | CLK32K | CLK_7816 | I2S_CLK | - | - | | PA[1] | SPI_SLV_CN | HSPI_CN_IO | DAC_I_DATO_I | UARTO_CTS_I | SPI_SLV_CN_I | - | | Pad | Default | Func1 | Func2 | Func3 | Func4 | Analog Func | |-------|---------|------------|----------------------------|--------------|---------------------------------|--------------------------| | PA[5] | GPIO | - | DAC_I_DAT1_I | - | DM_IO | - | | PA[6] | GPIO | - | DAC_Q_DAT1_I | - | DP_IO | - | | PA[7] | SWS_IO | - | - | - | SWS_IO | - | | PB[0] | GPIO | PWM5_O | TX_EN_I | TX_CYC2PA | HSPI_IO3_IO | lp_comp<0>/<br>sar_in<0> | | PB[1] | GPIO | PWM3_O | TX_ON_I | RX_CYC2LNA | CODEC_IRQ_<br>O/<br>HSPI_IO2_IO | lp_comp<1>/<br>sar_in<1> | | PB[2] | GPIO | TX_DATO_I | UARTO_TX/ DAC_I_DAT2_I | I2C_SCK_IO | DMIC_DAT_I/<br>HSPI_MISO_IO | lp_comp<2>/<br>sar_in<2> | | PB[3] | GPIO | TX_DAT1_I | UARTO_RTX_IO /DAC_I_DAT3_I | I2C_SDA_IO | DMIC_CLK1/<br>HSPI_MOSI_IO | lp_comp<3>/<br>sar_in<3> | | PB[4] | GPIO | TX_DAT2_I | UARTO_RTS/<br>DAC_I_DAT4_I | PWMO | DMIC_CLK2/<br>HSPI_CK_IO | lp_comp<4>/<br>sar_in<4> | | PB[6] | GPIO | RATEO_I | UARTO_CTS_I/ DAC_I_DAT6_I | PSPI_MISO_IO | TX_CYC2PA_O<br>/HSPI_CN_IO | lp_comp<6>/<br>sar_in<6> | | PB[7] | GPIO | RATE1_I | BT_INBAND/<br>DAC_I_DAT7_I | PSPI_MOSI_IO | CODEC_RSTN<br>_I/PWM2 | lp_comp<7>/<br>sar_in<7> | | PC[0] | GPIO | PWMO | RX_EN_I | PSPI_CN_IO | SWM_IO | - | | PC[1] | GPIO | DMIC_DAT_I | TX_CLK_I | ATSEL[0] | I2C_SCK_IO | - | | PC[2] | GPIO | ADC_I_DATO | DMIC_CLK1/<br>DAC_Q_DAT2_I | ATSEL[1] | I2C_SDA_IO | - | | PC[3] | GPIO | ADC_I_DAT1 | DMIC_CLK2/<br>DAC_Q_DAT3_I | ATSEL[2] | I2S_BCK_IO | - | | PD[0] | GPIO | PWM0_N | RX_CLK | PSPI_CN_IO | UARTO_CTS_I | xtl32k_in/<br>sar_in<8> | | PD[1] | GPIO | PWM1_N | ADC_I_DAT3 | PSPI_CK_IO | UARTO_RTS | xtl32k_out/<br>sar_in<9> | | PD[2] | GPIO | PWM2_N | ADC_I_DAT4 | PSPI_MISO_IO | UARTO_TX | - | | PD[3] | GPIO | PWM3_N | ADC_I_DAT5 | PSPI_MOSI_IO | UARTO_RTX_I<br>O | - | | PE[0] | GPIO | PWM3 | FREQ_CHN_I | UART1_TX | I2C_SCK_IO | - | | Pad | Default | Func1 | Func2 | Func3 | Func4 | Analog Func | |-------|---------|-------|------------|--------------|------------|-------------| | PE[2] | GPIO | PWM2 | ADC_Q_DAT4 | UART1_RTX_IO | I2C_SDA_IO | - | | PE[3] | GPIO | PWM0 | ADC_Q_DAT5 | UART1_RTS | I2C_SDA_IO | - | | PE[4] | GPIO | PWM4 | ADC_Q_DAT6 | RX_CYC2LNA | TDI_I | - | | PE[5] | GPIO | PWM5 | ADC_Q_DAT7 | TX_CYC2PA | TDO | - | | PE[6] | TMS | - | ADC_Q_DAT8 | PWM2_N | TMS_IO | - | | PE[7] | TCK | - | ADC_Q_DAT9 | PWM3_N | TCK_I | - | Flash IO multiple functions are listed in table below: Table 1-8 Flash IO Pin Mux | Pad | Default | Func1 | Func2 | |-------|---------|------------|------------| | PF[0] | MOSI | - | MOSI_IO(0) | | PF[1] | MSCK | - | MCLK | | PF[2] | MSIO3 | FAST_STL_I | MSIO3_IO | | PF[3] | MSCN | TX_PWR_I | MSCN | | PF[4] | MISO | - | MISO_IO | | PF[5] | MSIO2 | - | MSIO2_IO | # 2 Key Electrical Specifications **NOTE:** The electrical characteristics currently listed in this section are target specifications and only supplied for reference. Some data may be updated according to actual test results. ## 2.1 Absolute Maximum Rating Table 2-1 Absolute Maximum Rating | Characteristics | Sym. | Min. | Max. | Unit | Test Condition | |---------------------------|------------------|------|---------|------|----------------| | Supply Voltage | VBAT | -0.3 | 4.3 | V | - | | Voltage on Input Pin | V <sub>in</sub> | -0.3 | VDD+0.3 | V | - | | Output Voltage | V <sub>out</sub> | 0 | VDD | V | - | | Storage Temperature Range | T <sub>Str</sub> | -65 | 150 | | - | | Soldering Temperature | T <sub>Sld</sub> | - | 260 | | - | **NOTE:** Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. ## 2.2 Recommended Operating Conditions Table 2-2 Recommended Operating Conditions | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |---------------------------------------|------------------|------|------|------|------|-----------| | Power Supply Voltage | VBAT | 1.8 | 3.7 | 4.3 | V | - | | Supply Rise Time from 1.6 V to 1.8 V) | T <sub>R</sub> | - | - | 10 | ms | - | | Operating Temperature Range | T <sub>Opr</sub> | -40 | - | 85 | °C | - | ## 2.3 DC Characteristics Table 2-3 DC Characteristics(VBAT=4.2 V, $T = 25 \, ^{\circ}C$ ) | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |------------|-----------------|------|------|------|------|-------------------------------------------------| | RX Current | I <sub>Rx</sub> | - | 5 | - | mA | Whole Chip, EDR mode | | TX Current | I <sub>Tx</sub> | - | 13 | - | mA | whole chip @ 0 dBm with 4.2 V<br>DCDC, EDR mode | | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |-------------------------------------|--------------------|------|------|------|------|------------------------------------------| | RX Current | I <sub>Rx</sub> | - | 11.5 | - | mA | Whole Chip, EDR mode, with LDO | | TX Current | I <sub>Rx</sub> | - | TBD | - | mA | whole chip @ 0 dBm with LDO,<br>EDR mode | | RX Current | I <sub>Rx</sub> | - | 5 | - | mA | Whole Chip, BLE mode | | TX Current | I <sub>Rx</sub> | - | 5.5 | - | mA | Whole Chip @0 dBm, BLE mode | | RX Current | I <sub>Rx</sub> | - | 11.5 | _ | mA | Whole Chip, BLE mode, with LDO | | TX Current | I <sub>Rx</sub> | - | 12.5 | - | mA | Whole Chip @O dBm, BLE mode, with LDO | | Deep sleep with 32kB SRAM retention | I | - | 1.7 | - | μA | - | | Deep sleep with 64kB SRAM retention | I <sub>Deep1</sub> | - | TBD | - | μA | - | | Deep sleep without SRAM retention | I <sub>Deep2</sub> | _ | 0.7 | - | μA | - | ## 2.4 AC Characteristics Table 2-4 Digital Inputs/Outputs AC Characteristics (VDD = 3.3 V, T = 25 °C) | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |---------------------|------|--------|------|--------|------|-----------| | Input high voltage | VIH | 0.7VDD | - | VDD | V | - | | Input low voltage | VIL | VSS | - | 0.3VDD | V | - | | Output high voltage | VOH | 0.9VDD | - | VDD | V | - | | Output low voltage | VOL | VSS | - | 0.1VDD | V | - | ### NOTE: - The data is test result of engineering sample and may verify for mass production. - VDD stands for IO voltage, e.g, AVDD3, VDD3, or VDD3\_DCDC, the range of the IO voltage is 1.8 V $\sim$ 3.6 V, and typical value is 3.3V DS-TLSR9515-E5 33 Ver 0.8.4 Table 2-5 RF Performance AC Characteristics(VBAT = 4.2 V, T = $25 \,^{\circ}\text{C}$ ) | Data Rate | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |--------------------------|-------------------------------------------|---------------------|-------------|-------------|------|-----------------------------|---------------------------------------------------------------------| | | Sensitivity | - | - | -92 | - | dBm | - | | | Frequency Offset Tolerance | - | -300 | - | 300 | kHz | - | | | Maximum<br>received signal<br>at 0.1% BER | - | - | 0 | - | dBm | - | | | Co-channel rejection | - | - | 9 | - | dB | Wanted signal at -60 dBm | | BR RF_Rx performance | In-band<br>blocking | +1/-1 MHz<br>offset | - | -7/-7 | - | dB | Wanted signal at -60 | | | rejection<br>(Equal | +2/-2 MHz<br>offset | - | -47/<br>-33 | - | dB | dBm | | Modulation Interference) | +3/-3 MHz<br>offset | - | -46/<br>-45 | - | dB | Wanted signal at -67<br>dBm | | | | Image rejection | - | - | -33 | - | dB | Wanted signal at -60<br>dBm; image<br>frequency=RF_cha<br>nnel-2MHz | | Data Rate | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |-----------------------|-------------------------------------------|----------------|------|-------|------|------|-------------------| | | Output power,<br>maximum<br>setting | - | - | 10 | - | dBm | - | | | Transmitter power control step | - | - | 3 | - | dB | - | | | Output power control range | - | | 30 | | dB | - | | BR RF_TX performance | Initial carrier<br>frequency<br>offset | - | - | ±5 | - | KHz | - | | | Frequency<br>drift(DH3) | - | - | ±10 | - | KHz | - | | | Frequency<br>Deviation | ∆f1avg | - | 160 | - | kHz | 140 kHz ~ 175 kHz | | | | Δf2max | 115 | - | - | kHz | ≥ 115 kHz | | | | Δf2avg/Δf1avg | - | 0.9 | - | | ≥ 0.8 | | | Adjacent | M - N = 2 | - | - | -20 | dBm | - | | | channel power (ACP) | M - N = 3 | - | - | -40 | dBm | - | | | Caraikisks | EDR2<br>2 Mbps | - | -92.5 | - | dBm | - | | | Sensitivty | EDR3<br>3 Mbps | - | -86 | - | dBm | - | | EDR RF_RX performance | Frequency<br>Offset<br>Tolerance | - | -300 | - | 300 | kHz | - | | | Maximum<br>received signal<br>at 0.1% BER | - | - | 0 | - | dBm | - | | Data Rate | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |---------------------|-----------------------------|---------------------|-------------|-------------|------|-------------------------------------------------------------------------|-------------------------------------------------------------------------| | | Co-channel rejection | - | - | 9 | - | dB | Wanted signal at -60 dBm | | In-band<br>blocking | +1/-1 MHz<br>offset | - | -14/<br>-13 | - | dB | Wanted signal at -60 dBm | | | EDR2 | rejection (equal modulation | +2/-2 MHz<br>offset | - | -45/<br>-33 | - | dB | Wanted signal at -60 dBm | | EDR2 | interference) | +3/-3 MHz<br>offset | - | -45/<br>-45 | - | dB | Wanted signal at -67 | | Image rejection | - | - | -33 | - | dB | Wanted signal at -67<br>dBm; image<br>frequency =<br>RF_channel - 2 MHz | | | | Co-channel rejection | - | - | 16 | - | dB | Wanted signal at -60 dBm | | | In-band<br>blocking | +1/-1 MHz<br>offset | - | -7/-7 | - | dB | Wanted signal at -60 dBm | | EDR3 | rejection (equal modulation | +2/-2 MHz<br>offset | - | -34/<br>-28 | - | dB | Wanted signal at -60 dBm | | inte | interference) | +3/-3 MHz<br>offset | - | -45/<br>-45 | - | dB | Wanted signal at -67 | | | Image rejection | - | - | -28 | - | dB | Wanted signal at -67<br>dBm; image<br>frequency =<br>RF_channel - 2 MHz | | Data Rate | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |-----------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|------------|---------------|------|------|------|-----------| | Output power, maximum setting Transmitter power control step Output power control range Initial carrier frequency offset | - | - | 1.5 | - | dBm | - | | | | 3 - | | - | dB | - | | | | | | - 30 | | | | dB | - | | | frequency | - | - | ±5 | - | KHz | - | | | Frequency drift | EDR2(2DH5) | R2(2DH5) - ±5 | | - | KHz | - | | EDR RF_TX | | EDR3(3DH5) | - | 15 | - | KIIZ | - | | performance | EDR2 Adjacent<br>channel power<br>(ACP) | M - N = 2 | - | - | -20 | | - | | | | M - N = 3 | - | - | -40 | dBm | - | | | EDR3 Adjacent | M - N = 2 | - | - | -20 | | - | | | channel power | M - N = 3 | - | - | -40 | dBm | - | | | EDR2 | RMS DEVM | - | 8 | - | | ≤20% | | | modulation | PEAK DEVM | - | 20 | - | % | ≤30% | | | accuracy | 99% DEVM | - | - | 35 | | ≤35% | | | EDR3 | RMS DEVM | - | 8 | - | | ≤13% | | | modulation | PEAK DEVM | - | 20 | - | % | ≤25% | | | accuracy | 99% DEVM | - | - | 20 | 1 | ≤20% | | Data Rate | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |------------------------------------------------------------|---------------------------------------|---------------------|------|---------|------|------|-----------------------------| | | Sensitivity | 1 Mbps | - | -95.5 | - | dBm | - | | Frequency Offset Tolerance Co-channel BLE 1 Mbps rejection | Offset | - | -300 | - | 300 | kHz | Wanted signal at -<br>67dBm | | | | - | - | 7 | - | dB | - | | RF_RX performance (±250kHz | In-band<br>blocking | +1/-1 MHz<br>offset | - | -3/-2 | - | dB | | | deviation) | rejection<br>(Equal | +2/-2 MHz<br>offset | - | -41/-38 | - | dB | Wanted signal at -<br>67dBm | | | Modulation Interference) | >=3 MHz<br>offset | - | -49 | - | dB | | | | Image rejection | - | - | -38 | - | dB | Wanted signal at -<br>67dBm | | | Output power,<br>maximum<br>setting | - | - | 10 | - | dBm | - | | BLE 1 Mbps | Output power,<br>minimum<br>setting | - | - | -24 | - | dBm | - | | RF_TX<br>performance | Programmable<br>output power<br>range | | | 34 | | dB | - | | | Modulation<br>20dB<br>bandwidth | - | - | 1.4 | - | MHz | - | | Data Rate | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |------------------------------------------------------------|-------------------------------------|---------------------|------|-------------|------|------|-----------------------------| | | Sensitivity | 2 Mbps | - | -92.5 | - | dBm | - | | Frequency Offset Tolerance Co-channel BLE 2 Mbps rejection | Offset | - | -300 | - | 300 | kHz | Wanted signal at -<br>67dBm | | | | - | - | 8 | - | dB | - | | RF_RX<br>performance<br>(±500kHz | In-band<br>blocking | +2/-2 MHz<br>offset | - | -7/-7 | - | dB | | | deviation) | rejection<br>(Equal | +4/-4 MHz<br>offset | - | -37/<br>-38 | - | dB | Wanted signal at - | | | Modulation Interference) | >=4 MHz<br>offset | - | -44/<br>-44 | - | dB | | | | Image rejection | - | - | -25 | - | dB | Wanted signal at -<br>67dBm | | | Output power,<br>maximum<br>setting | - | - | 10 | - | dBm | - | | BLE 2 Mbps | Output power,<br>minimum<br>setting | - | - | -24 | - | dBm | - | | RF_TX<br>performance | Programmable output power range | - | | 34 | | dB | - | | | Modulation<br>20dB<br>bandwidth | - | - | 2.4 | - | MHz | - | | Data Rate | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |-----------------------------|-------------------------------------|---------------------|------|-------------|------|------|-----------------------------| | | Sensitivity | 500 kbps | - | -98.5 | - | dBm | - | | | Frequency<br>Offset<br>Tolerance | - | -300 | - | 300 | kHz | - | | BLE 500 kbps<br>RF_RX | Co-channel rejection | - | - | 6 | - | dB | Wanted signal at -72<br>dBm | | performance<br>(±250kHz | In-band<br>blocking | +1/-1 MHz<br>offset | - | -3/-3 | - | dB | | | deviation) rejection (Equal | | +2/-2 MHz<br>offset | - | -42/<br>-38 | - | dB | Wanted signal at -72<br>dBm | | | Interference) | >=3MHz offset | - | -42 | - | dB | | | | Image rejection | - | - | -38 | - | dB | Wanted signal at -72<br>dBm | | | Output power,<br>maximum<br>setting | - | - | 10 | - | dBm | - | | BLE 500 kbps | Output power,<br>minimum<br>setting | - | - | -24 | - | dBm | - | | RF_TX<br>performance | Programmable output power range | - | | 34 | | dB | - | | | Modulation<br>20dB<br>bandwidth | - | - | 1.4 | - | MHz | - | | Data Rate | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |----------------------------|---------------------------------------|---------------------|------|-------------|------|------|-----------------------------| | | Sensitivity | 125 kbps | - | -99.5 | - | dBm | - | | | Frequency<br>Offset<br>Tolerance | - | -300 | _ | 300 | kHz | - | | BLE 125 kbps | Co-channel rejection | - | - | 5 | - | dB | Wanted signal at -67 | | RF_RX performance (±250kHz | In-band<br>blocking | +1/-1 MHz<br>offset | - | -3/-3 | - | dB | | | deviation) | rejection<br>(Equal | +2/-2 MHz<br>offset | - | -42/<br>-27 | - | dB | Wanted signal at -67<br>dBm | | | Modulation Interference) | >=3MHz offset | - | -42/<br>-36 | - | dB | | | | Image rejection | - | - | -27 | - | dB | Wanted signal at -67 | | | Output power,<br>maximum<br>setting | - | - | 10 | - | dBm | - | | BLE 125 kbps | Output power,<br>minimum<br>setting | - | - | -24 | - | dBm | - | | RF_TX performance | Programmable<br>output power<br>range | - | | 34 | | dB | - | | | Modulation<br>20dB<br>bandwidth | - | - | 1.4 | - | MHz | - | ## Table 2-6 USB Characteristics | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |-------------------------------------|------------------|------|------|------|------|-----------| | Output Signal Cross-over<br>Voltage | V <sub>Crs</sub> | 1.3 | - | 2.0 | V | - | #### Table 2-7 RSSI Characteristics | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |------------|------|------|------|------|------|-----------| | RSSI Range | - | -100 | - | 10 | dBm | - | | Resolution | - | - | ±1 | - | dB | - | ## Table 2-8 24MHz Crystal Characteristics | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |---------------------------------------|------------------|------|------|------|------|-------------------------------| | Nominal frequency (parallel resonant) | f <sub>NOM</sub> | - | 24 | - | MHz | - | | Frequency tolerance | f <sub>TOL</sub> | -20 | | +20 | ppm | - | | Load capacitance | CL | 5 | 12 | 18 | ρF | Programmable on chip load cap | | Equivalent series resistance | ESR | - | 50 | 100 | ohm | - | ## Table 2-9 32.768 kHz Crystal Characteristics | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |---------------------------------------|------------------|------|--------|------|------|-----------| | Nominal frequency (parallel resonant) | f <sub>NOM</sub> | - | 32.768 | - | kHz | - | | Frequency tolerance | f <sub>TOL</sub> | -100 | - | +100 | ppm | - | | Equivalent series resistance | ESR | - | 50 | 80 | ohm | | ## Table 2-10 24 MHz RC Oscillator Characteristics | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |---------------------|------------------|------|------|------|------|---------------------| | Nominal frequency | f <sub>NOM</sub> | - | 24 | - | MHz | - | | Frequency tolerance | f <sub>TOL</sub> | - | 1 | - | % | On chip calibration | #### Table 2-11 32 kHz RC Oscillator Characteristics | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |---------------------|------------------|------|------|------|------|---------------------| | Nominal frequency | f <sub>NOM</sub> | - | 32 | - | kHz | - | | Frequency tolerance | f <sub>TOL</sub> | - | 0.03 | - | % | On chip calibration | | Calibration time | - | - | 3 | - | ms | - | DS-TLSR9515-E5 42 Ver 0.8.4 Table 2-12 ADC Characteristics | Item | Sym. | Min. | Тур. | Max. | Unit | Condition | |--------------------------------------|-------|------|------|------|------|-----------------------| | Differential nonlinearity | DNL | - | - | 1 | LSB | 10bit resolution mode | | Integral nonlinearity | INL | - | - | 2 | LSB | 10bit resolution mode | | Signal-to-noise and distortion ratio | SINAD | - | 70 | - | dB | fin=1 kHz, fS=16 kHz | | Effective Number of Bits | ENOB | - | 10.5 | - | bits | - | | Sampling frequency | Fs | - | - | 200 | ksps | - | # 2.5 Analog Input to Digital Output Measurement conditions: Input sine wave with a frequency of 1kHz, measurement bandwidth 20Hz-Fs/2 for Fs=8 to 32 kHz, measurement bandwidth 20 Hz -20 kHz for Fs=44.1 kHz to 96 kHz, unless otherwise specified. Table 2-13 Analog Microphone / Line Input to ADC Path | Parameter | Test conditions | Min. | Тур | Max. | Unit | |--------------------------|-------------------------------------------------------------------------------------------------|-------|-------|-------|------| | Input level <sup>a</sup> | Full Scale, Gain = 0 dB, boost gain = 20 dB | 0.189 | 0.212 | 0.239 | Vpp | | SNR | A-weighted, 1 kHz sine wave @ Full Scale and gain = 0 dB, boost gain = 0 dB | 85 | 90 | - | dB | | SINK | A-weighted, 1 kHz sine wave @ Full Scale and gain = 0 dB, boost gain = 20 dB | 75 | 80 | - | dB | | THD | 1 kHz sine wave @ Full Scale - 1 dB and gain = 0 dB,<br>boost gain = 0 dB | - | -80 | -70 | dB | | Inu | 1 kHz sine wave @ Full Scale - 1 dB and gain = 0 dB,<br>boost gain = 20 dB | - | -70 | -60 | dB | | THD+N <sup>b</sup> | A-weighted, 1 kHz sine wave @ Full Scale -60 dB and gain = 0 dB, boost gain = 0 dB | 85 | 90 | - | dB | | THD+N- | A-weighted, 1 kHz sine wave @ Full Scale -60 dB and gain = 0 dB, boost gain = 20 dB | 75 | 80 | - | dB | | Dynamic<br>Range | A-weighted, 1 kHz sine wave @ Full Scale -60 dB and gain = 0 dB, boost gain = [0-20] dB | - | 100 | - | dB | | PSRR | 100 mVpp 1 kHz sine wave is applied to AVD, input data is 0 and gain = 0 dB, boost gain = 20 dB | - | 90 | - | dB | | Parameter | Test conditions | Min. | Тур | Max. | Unit | |---------------------|------------------------------------------------------|------|-----|------|------| | Boost gain | When activated | 0 | - | 20 | dB | | Boost gain step | @1 kHz | - | 4 | - | dB | | Boost gain accuracy | @1 kHz | | | +1 | dB | | locut resistance | Boost gain = 0 dB, differential configuration | 132 | 160 | 200 | kOhm | | Input resistance | Boost gain = 20 dB, differential configuration | 20 | 26 | 30 | kOhm | | loout registeres | Boost gain = 0 dB, single-ended configuration | 92 | 115 | 138 | kOhm | | Input resistance | Boost gain = 20 dB, single-ended configuration | 19 | 24 | 29 | kOhm | | Input capacitance | Includes 10 pF for ESD, bonding and package pins cap | - | - | 25 | ρF | | Input capacitance | Cbyline | - | 1 | - | μF | a. The Full Scale input voltage scales with embedded reference: VCAP # 2.6 Digital Input to Analog Output Measurement conditions: input sine wave with a frequency of 1 kHz, measurement bandwidth 20 Hz–20 kHz, unless otherwise specified. Table 2-14 Audio DAC to Headphone Output Path | Parameter | Test conditions | Min. | Тур | Max. | Unit | |----------------------|--------------------------------------------------------------------------------------------------------|------|------|------|------| | | 1 kHz sine wave @ Full Scale -1 dB and gain GOL/R= +6 dB, GODL/R= 0 dB, 10 kOhms load | 3.78 | 3.69 | 4.78 | Vpp | | Output level | Full Scale and gain GOL/R= -3 dB, GODL/R= 0 dB, 16 Ohms load | 1.35 | 1.5 | 1.65 | Vpp | | | Full Scale and gain GOL/R= +6 dB, GODL/R=0 dB, 16<br>Ohms load | - | 3.5 | - | Vpp | | Maximum output power | 16 Ohms load | - | - | 95 | mW | | SNR | A-weighted, 1 kHz sine wave @ Full Scale and gain GOL/R = +6 dB, GODL/R= 0 dB, 10 kOhms load | | 97 | - | dB | | SNR | A-weighted, 1 kHz sine wave @ Full Scale and gain GOL/R= +6 dB, GODL/R = 0 dB, 16/32 Ohms load | 90 | - | 97 | dB | | Dynamic Range | A-weighted, 1 kHz sine wave @ Full Scale and gain<br>GOL/R = [-10 + 6] dB, GODL/R = 0 dB, 16 Ohms load | - | 106 | - | dB | b. The specified value is extrapolated by adding 60 dB to the measured SNR | Parameter | Test conditions | Min. | Тур | Max. | Unit | |------------------------------|-------------------------------------------------------------------------------------------------------------------------|------|--------|------|------| | Idle Noise | A-weighted with no signal and gain GOL/R = -10 dB,<br>GODL/R = 0 dB, 16 Ohms load | | -104.5 | -98 | dBV | | TUD | 1 kHz sine wave @ Full Scale -1 dB and gain GOL/R = +6 dB, GODL/R = 0 dB, 10 kOhms load | - | -85 | -75 | dB | | THD | 1 kHz sine wave @ Full Scale -1 dB and gain GOL/R = -3 dB, GODL/R = 0 dB, 16 Ohms load | - | -70 | -65 | dB | | THD+N <sup>a</sup> | A-weighted, 1 kHz sine wave @ Full Scale -60 dB and gain GOL/R = +6 dB, GODL/R = 0 dB, 10 kOhms load | 90 | 95 | - | dB | | Wide Band | Noise1 kHz sine wave @ Full Scale and gain GOL/R = +6 dB, GODL/R = 0 dB, 10 kOhms load, measurement on 20 kHz - 100 kHz | - | 75 | - | dB | | PSRR | 100 mVpp 1 kHz is applied to AVD, input data is 0 and gain $GOL/R = 0$ dB, $GODL/R = 0$ dB, 10 kOhms load | - | 90 | - | dB | | Analog gain | Gain GOL/R | -19 | _ | +12 | dB | | Digital gain | Gain GODL/R | -31 | - | +32 | dB | | Gain step | GOL/R, GODL/R @ 1 kHz | - | 1 | - | dB | | Gain accuracy | GOL/R, GODL/R @ 1 kHz | -0.5 | - | +0.5 | dB | | D 11: | Active < - > Inactive, 10 kOhms load | - | -60 | - | dBV | | Pop-up Noise | Active < - > Inactive, 16 Ohms load | - | -60 | - | dBV | | Output load resistance (RI) | - | 16 | - | - | Ohm | | Output load capacitance (Cp) | - | - | - | 200 | ρF | a. The specified value is extrapolated by adding 60 dB to the measured SNR. # 2.7 MICBIAS Characteristics Measurement conditions: input sine wave with a frequency of 1 kHz, measurement bandwidth 20 Hz–20 kHz, unless otherwise specified. Table 2-15 MICBIAS Characteristics | Parameter | Test Condition | Min. | Тур. | Max. | Unit | |-------------------------------|----------------|------|------|------|-------| | | MICBIAS_V = 0 | - | 2.08 | - | V | | MICBIAS Output Level | MICBIAS_V = 1 | - | 1.66 | - | V | | MICBIAS Output Current | - | - | - | 4 | mA | | MICBIAS Output Noise | A-Weighted | - | 20 | 40 | uVrms | | MICBIAS Decoupling Capacitor | Cmic | 0.75 | 1 | 1.25 | nF | | VREFP_CODEC Output<br>Voltage | - | - | 2.5 | - | V | | VCAP Output Voltage | - | - | 2 | - | V | # 2.8 Digital Microphone Interface Characteristics Measurement conditions: Input sine wave with a frequency of 1kHz, MCLK = 12 MHz or 13 MHz, DMIC\_CLK = Fmclk/4, measurement bandwidth 20 Hz - Fs/2 for Fs = 8 to 32 kHz, measurement bandwidth 20 Hz - 20 kHz for Fs = 44.1 kHz to 96 kHz, unless otherwise specified. Table 2-16 Digital Microphone Interface Characteristics | Parameter | Test Condition | Min. | Тур. | Max. | Unit | |--------------------------|--------------------------------------------------------------------|-------|------|-------|------| | 1 1118 | Full Scale max value, Gain GID = 0 dB | 84.5 | 85.6 | 86.7 | % | | Input Level <sup>a</sup> | Full Scale min value, Gain GID = 0 dB | 15.5 | 14.4 | 13.3 | % | | SNR | A-weighted, 1 kHZ sine wave@ Full Scale and gain GIDL, GIDR = 0 dB | | 100 | | dB | | THD+N | 1 kHZ sine wave@ Full Scale - 1 dB and gain GIDL, GIDR = 0 dB | 90 | | | dB | | THD+N <sup>b</sup> | A-weighted, 1 kHZ sine wave@ Full Scale -60 dB and gain GID = 0 dB | | | dB | | | Digital Gain | Gain GID when activated | 0 | - | 43 | dB | | Gain Step | GID @ 1 kHz | - | 1 | - | dB | | Gain Accuracy | GID @ 1 kHz | -0.25 | - | +0.25 | dB | a. The Full Scale input corresponds to a modulation density of the PDM input DS-TLSR9515-E5 46 Ver 0.8.4 b. The specified value is extrapolated by adding 60 dB to the measured SNR # 2.9 Storage Condition The SoC series is applicable to Moisture Sensitivity Level 3 (based on JEDEC Standard). - 1. Calculated shelf life in sealed moisture barrier bag (MBB): 12 months at <40°C and <90% relative humidity (RH) - 2. Peak package body temperature: 260°C - 3. After bag is opened, devices that will be subjected to reflow solder or other high temperature process must be - Mounted within: 168 hours of factory conditions <=30°C/60% RH, or</li> - Stored at <10% RH</li> - 4. Devices require bake, before mounting, if: - Humidity Indicator Card reads >10% when read at 23 ± 5°C - · Both of the conditions in 3 are not met - 5. If baking is required, devices may be baked for 24 hours at 125 ±5°C Note: If device containers cannot be subjected to high temperature or shorter bake times are desired, please refer to IPC/JEDEC J-STD-033 for bake condition. DS-TLSR9515-E5 47 Ver 0.8.4 # 3 Reference Design # 3.1 Schematic Figure 3-1 Schematic of TLSR9515A Figure 3-2 Schematic of TLSR9515B DS-TLSR9515-E5 48 Ver 0.8.4 Figure 3-3 Schematic of TLSR9515D # 3.2 BOM (Bill of Material) Table 3-1 BOM Table of TLSR9515A | Quantity | Reference | Value | Description | PCB Footprint | |----------|-------------------------------------------------------------------------------|-------------------------|----------------------------------------------------|---------------------------------| | 1 | C1 | 0.1uF | Capacitance,X5R,±10% | 0402 | | 1 | C2 | 2.2uF | Capacitance,X5R,±10% | 0402 | | 2 | C3, C4 | 1.5pF | Capacitance,COG,±0.1pF | 0402 | | 15 | C5, C6, C7, C9, C10,<br>C11, C12, C13,<br>C14, C15, C17, C18,<br>C19, C8, C16 | 1uF | Capacitance,X5R,±10% | 0402 | | 1 | L1 | 2.2nH | High frequency chip inductor,<br>±0.3nH | 0402 | | 2 | L2, L3 | 10uH | High frequency chip inductor,<br>SMD,20% | 0805L | | 1 | U1 | TLSR9515A | BT SOC | qfn_4x6_40pin_0p4_2<br>p80x4p80 | | 1 | Y1 | 24MHz-12pF-<br>+/-20ppm | XTAL SMD 3225,24 MHz,<br>CI=12pF, total tol.±20ppm | OSCCC250X320X110 | Figure 3-4 BOM Table of TLSR9515B | Quantity | Reference | Value | Description | PCB Footprint | |----------|--------------------------------------------------------------------------|-------------------------|----------------------------------------------------|---------------------------------| | 1 | C1 | 0.1uF | Capacitance,X5R,±10% | 0402 | | 1 | C2 | 2.2uF | Capacitance,X5R,±10% | 0402 | | 2 | C3, C4 | 1.5pF | Capacitance,COG,±0.1pF | 0402 | | 14 | C5, C6, C7, C9, C11,<br>C12, C13,<br>C14, C15, C17, C18,<br>C19, C8, C16 | 1uF | Capacitance,X5R,±10% | 0402 | | 1 | L1 | 2.2nH | High frequency chip inductor,<br>±0.3nH | 0402 | | 2 | L2, L3 | 10uH | High frequency chip inductor,<br>SMD,20% | 0805L | | 1 | U1 | TLSR9515B | BT SOC | qfn_4x6_40pin_0p4_2<br>p80x4p80 | | 1 | Y1 | 24MHz-12pF-<br>+/-20ppm | XTAL SMD 3225,24 MHz,<br>CI=12pF, total tol.±20ppm | OSCCC250X320X110 | Table 3-2 BOM of TLSR9515D | Quantity | Reference | Value | Description | PCB Footprint | |----------|--------------------------------------------------------------------------|-------|-----------------------------------------|---------------| | 2 | C1, C4 | NC | Capacitance,X5R,±10% | 0402 | | 1 | C2 | O.1uF | Capacitance,X5R,±10% | 0402 | | 1 | C3 | 2.2uF | Capacitance,X5R,±10% | 0402 | | 1 | C6 | 1.8pF | Capacitance,COG,±0.1pF | 0402 | | 1 | C7 | 1pF | Capacitance,COG,±0.1pF | 0402 | | 13 | C10, C11, C12, C13,<br>C15, C17, C21, C22,<br>C27, C29, C31, C33,<br>C62 | 1uF | Capacitance,X5R,±10% | 0402 | | 1 | C30 | 10uF | Capacitance,X5R,±10% | | | 1 | C38 | 1uF | Capacitance,X5R,±10% | 0402 | | 1 | L1 | 2.4nH | High frequency chip inductor,<br>±0.3nH | 0402 | | Quantity | Reference | Value | Description | PCB Footprint | |----------|---------------|-------------------------|--------------------------------------------------------------|---------------------------------| | 2 | L3, L4 | 10uH | High frequency chip inductor,<br>SMD,20% | 1008L | | 3 | R11, R13, R14 | 4.7K | Resistance, 5% | 0402 | | 1 | U1 | TLSR9515D | RF SOC | qfn_7x7_56pin_0p4_4<br>p10x4p10 | | 1 | U5 | P25Q8OU | Flash | W25X10_20_40BL | | 1 | Y1 | 24MHz-12pF-<br>+/-20ppm | XTAL RADIAL 2x6mm,<br>32.768KHz, CI=9pF, total<br>tol.±20ppm | OSCCC250X320X110 | # 4 Memory, MCU and PMU # 4.1 Memory The SoC embeds 128 KB SRAM (including 64KB with retention in deep sleep) as instruction memory, 128 KB SRAM as data memory, and 1MB/512KB internal or maximum 16 MB external FLASH as program memory. #### NOTE: - TLSR9515D embeds 2MB external FLASH - TLSR9515A embeds 1MB internal FLASH - TLSR9515B embeds 512KB internal FLASH ## 4.1.1 SRAM Memory map is shown below. As shown in Figure 4-1, the SoC embedded 2 SRAM, 128 KB instruction local memory (ILM) and 128 KB data local memory (DLM). For ILM, the lower 64 KB is with retention in deep sleep. ILM and DLM have different addressing address for MCPU (shown as ILM\_CPU and DLM\_CPU). Please be noted, ILM can store both instruction and data while DLM can only store data, so the instruction stored in local memory should be less than 128 KB. DS-TLSR9515-E5 52 Ver 0.8.4 rsvd DEBUG rsvd PLIC\_SW rsvd PLMT rsvd ZB APB rsvd DLM AUDIO\_APB rsvd rsvd PWM HSPI rsvd rsvd GPIO ZB rsvd APB\_SPACE APB\_SPACE I2C AUDIO rsvd STIMER rsvd PKE ALG rsvd TIMER TRNG MSPI rsvd UART1 SWIRE USB PSPI DMA APBRG BMC rsvd FLASH rsvd DLM CPU rsvd ILM CPU Figure 4-1 Memory Map ## 4.1.2 Flash For TLSR9515A/B, the internal Flash mainly supports page program, sector/block/chip erase operations, and deep power down operation. Please refer to the corresponding SDK for Flash memory operation details. MCU uses the separate MSPI\_CLK frequency to load instructions, and adopts flash driver to access (read/write) flash with the same speed. TLSR9515D embeds a MSPI interface for external Flash. #### 4.1.3 E-Fuse The non-volatile E-Fuse section is preloaded with 4-byte decryption key and 4-byte E-Fuse configuration, decryption key is shown below. Table 4-1 E-Fuse Information | E-Fuse bit information | Decryption Key | |------------------------|----------------| | | BitO~31 | DS-TLSR9515-E5 53 Ver 0.8.4 ## 4.1.4 Unique ID For chip identification and traceability, the flash is preloaded with 128-bit Unique ID (UID). This UID can be read via the interface in SDK. ## 4.2 MCU The SoC embeds a 32-bit RISC-V micro-controller, features are listed as following: - 1. 5-stage in-order execution pipeline - 2. Fast Hardware multiplier - 3. Hardware divider - 4. Dynamic branch prediction - 32-entry branch target buffer (BTB) - 5. Performance monitors - 6. Misaligned memory accesses - 7. RISC-V RV32I base integer instruction set - 8. RISC-V RVC standard extension for compressed instructions - 9. RISC-V RVM standard extension for integer multiplication and division - 10. RISC-V RVA standard extension for atomic instructions - 11. RISC-V RVN standard extension for user-level interrupt and exception handling - 12. RISC-V "F" standard extensions for single-precision floating-point - 13. I & D caches - 14. I & D local memories ## 4.3 Working Mode The SoC supports six working modes, including Active, Idle, Suspend, Deep Sleep with SRAM retention, Deep Sleep without SRAM retention, and Shutdown. - The Power Management (PM) module is always active in all working modes. - For modules such as MCU, RF transceiver (Radio), and SRAM, the state depends on working mode, as shown below. Table 4-2 Working Mode | Mode | Active | ldle | Suspend | Deep Sleep<br>With SRAM<br>Retention | Deep Sleep<br>without<br>SRAM<br>Retention | Shut Down | |-------|-----------|---------------|-----------|--------------------------------------|--------------------------------------------|-----------| | MCU | active | stəll | stəll | off | off | off | | Radio | available | available | off | off | off | off | | USB | available | available/off | stall/off | off | off | off | DS-TLSR9515-E5 54 Ver 0.8.4 | Mode | Active | ldle | Suspend | Deep Sleep<br>With SRAM<br>Retention | Deep Sleep<br>without<br>SRAM<br>Retention | Shut Down | |--------------------------------------------------|-----------|---------------|-----------|-------------------------------------------------------------------|--------------------------------------------|-----------| | Audio | available | available/off | stall/off | off | off | off | | Wakeup Time<br>to Active<br>Mode<br>in LDO Mode | - | O µs | 100 µs | Shorter than Deep sleep without retention, almost same as Suspend | 1 ms | 10 ms | | Wakeup Time<br>to Active<br>Mode<br>in DCDC Mode | - | - | - | - | - | - | | retention SRAMs (with retention in deep sleep) | full | full | full | full | off | off | | Wakeup on<br>RTC<br>(32K Timer<br>wakeup) | - | - | available | available | available | off | | Wakeup on<br>pin<br>(IO wakeup) | - | - | available | available | available | off | | Wakeup on interrupt | - | available | - | - | - | - | | Wakeup on<br>reset pin<br>(RESETB) | - | available | available | available | available | on | #### NOTE: - active: MCU is at working state. - stall: In Idle and Suspend mode, MCU does not work, while its clock is still running. - available for modules: It's selectable to be at working state, or stall/be powered down if it does not need to work. - available/on for wakeup: Corresponding wakeup method is supported. - off for wakeup: Corresponding wakeup method is not supported. - full/off for SRAMs: - ofull: Full speed. In Active, Idle and Suspend mode, the two 16kB retention SRAMs are powered on and work normally (can be accessed); in Deep sleep with SRAM retention, the retention SRAMs are powered on, however, the contents of the retention SRAMs can be retained and cannot be accessed. - ° off: The retention SRAMs are powered down in Deep sleep without SRAM retention and Shutdown mode. Analog registers (0x37 ~ 0x3f) as shown in Table 4-3 are retained in deep sleep mode and can be used to store program state information across deep sleep cycles. - Analog registers 0x3c-0x3f are non-volatile even when chip enters deep sleep or chip is reset by watchdog or software, i.e. the contents of these registers won't be changed by deep sleep or watchdog reset or chip software reset. - Analog registers 0x37~0x3b are non-volatile in deep sleep, but will be cleared by watchdog reset or chip software reset. - After POR (Power-On-Reset), all registers will be cleared to their default values, including these analog registers. User can set flag in these analog registers correspondingly, so as to check the booting source by reading the flag. Table 4-3 Retention Analog Registers in Deep Sleep | Address | R/W | Description | Reset Value | |----------|-----|--------------------------|-------------| | afe_0x37 | R/W | buffer clean at watchdog | 11111111 | | afe_0x38 | R/W | buffer clean at watchdog | 0000000 | | afe_0x39 | R/W | buffer clean at watchdog | 0000000 | | afe_0x3a | R/W | buffer clean at watchdog | 0000000 | | afe_0x3b | R/W | buffer clean at watchdog | 0000000 | | afe_0x3c | R/W | buffer clean at power on | 0000000 | | afe_0x3e | R/W | buffer clean at power on | 0000000 | | afe_0x3f | R/W | buffer clean at power on | 00001111 | ## 4.4 Reset The chip supports three types of reset methods, including POR (Power-On-Reset), watchdog reset and software reset. - 1. POR: After power on, the whole chip will be reset, and all registers will be cleared to their default values. - 2. Watchdog reset: A programmable watchdog is supported to monitor the system. If watchdog reset is triggered, registers except for the retention analog registers 0x3c~0x3f will be cleared. - 3. Software reset: It is also feasible to carry out software reset for the whole chip or some modules. - Setting address 0x2f[5] as 1b'1 is to reset the whole chip. Similar to watchdog reset, the retention analog registers 0x3c~0x3f are non-volatile, while other registers including 0x37~0x3b will be cleared by chip software reset. - Addresses 0x20~0x22 serve to reset individual modules: if some bit is set to logic "1", the corresponding module is reset. Table 4-4 Register Configuration for Software Reset | Address | R/W | Description | Reset Value | |----------|-----|-----------------------------------------|-------------| | | | Reset control, 1 for reset, 0 for clear | | | | | [O]: HSPI | | | | | [1]: I2C | | | | | [2]: UARTO | | | 0x20 | R/W | [3]: USB | 08x0 | | | | [4]: PWMO | | | | | [5]: RSVD | | | | | [6]: UART1 | | | | | [0] RSVD | | | | 201 | [1] System Timer | 0x80 | | | | [2] DMA | | | 0.24 | | [3] ALGM | | | 0x21 | R/W | [4] PKE | | | | | [5] RSVD | | | | | [6] PSPI | | | | | [7] SPISLV | | | | | [O] TIMER | | | | | [1]AUDIO | | | 0x22 R/V | | [2] TRNG | | | | R/W | [3] RESET MCU DISABLE | 0x38 | | | | [4] MCU RESET ENABLE | | | | | [5] LM | | | | | [6] AI | | | | | [7] RSVD | | | Address | R/W | Description | Reset Value | |---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | Ox23 | R/W | [0] ZB [1] ZB_MSTCLK [2] ZB_LPCLK [3] ZB_CRYPT [4] RSVD [5] RSVD [6] SARADC [7] ALG | 0x80 | | Ox2f | R/W | [0] suspend enable (RW) [4] ramcrc_clren_tgl [5] rst all (act as watchdog reset) [6] rsvd (mcu low power mode) (W) [7] stall mcu trig If bit[0] set 1, then system will go to suspend. Or only stall mcu (W) | 0x00 | ## 4.5 Power Management The multiple-stage Power Management (PM) module is flexible to control power state of the whole chip or individual functional blocks such as MCU, RF Transceiver, and peripherals by the following methods: - 1. Power-On-Reset (POR) and Brown-out detect - 2. Working Mode Switch - 3. LDO and DCDC - 4. VBAT and VANT Power-Supply Mode ## 4.5.1 Power-on-Reset (POR) and Brown-out Detect Figure below shows the control logic of power up/down. Figure 4-2 Control Logic of Power up/down As shown in figure above, the whole power up and down is controlled by the UVLO (Ultra-low Voltage Lockout) & PL (Power Logic) module and the external RESETB pin via the logic shown in the above diagram. UVLO takes the external power supply as input and releases the lock only when the power supply voltage is higher than a preset threshold. The RESETB pin has an internal pull-up resistor; an external Cap can be connected on the RESETB pin to control the POR delay. After both UVLO and RESETB release, there is a further configurable delay before the system reset signal ("Sysrst") is released. The delay is adjusted by analog register afe\_0x40. Since the content of afe\_0x40 is reset to default only after power cycle, watchdog reset, or software reset, the delay change using afe\_0x40 is only applicable when the chip has not gone through these reset conditions. For example, after deep sleep wakeup, the setting in afe\_0x40 will take effect. Register afe\_0x40 is described in table below. Table 4-5 Analog Register to Control Delay Counters | Address | R/W | Description | Reset Value | |----------|-----|-----------------------------------------------|-------------| | afe_0x40 | R/W | base on 16KHz frequency increase counter(8ms) | 10000000 | Power up and power down sequences are shown in figures below. DS-TLSR9515-E5 59 Ver 0.8.4 Figure 4-3 Initial Power-up Sequence ## Initial Power up Figure 4-4 Initial Power-down Sequence Table 4-6 Characteristics of Initial Power-up/Power-down Sequence | Symbol | Parameter | Min. | Тур. | Max. | Unit | |------------------|--------------------------------------------------------|-----------|------|-------------|------| | V <sub>POR</sub> | VDD voltage when V <sub>UVLO</sub> turns to high level | - | 1.73 | - | V | | V <sub>PDN</sub> | VDD voltage when V <sub>UVLO</sub> turns to low level | - | 1.61 | _ | V | | T <sub>DLY</sub> | Delay counter value | Configura | | alog regist | er | ## 4.5.2 Working Mode Switch In Active mode, MCU is active, all SRAMs are accessible, and other modules are selectable whether to be at working state. The chip can switch to Idle mode to stall the MCU. In this mode, all SRAMs are still accessible, modules such as RF transceiver, USB are still selectable whether to be at working state. The chip can be triggered to Active mode by interrupt or RESETB pin, and the time to switch to Active mode is negligible. To decrease power consumption to different levels, the chip can switch to power saving mode (Suspend, Deep sleep with SRAM retention, Deep sleep without SRAM retention, Shutdown) correspondingly. - In Suspend mode, MCU stalls, all SRAMs are still accessible, the PM module is active, and modules such as RF transceiver, USB are powered down. The chip can be triggered to Active mode by 32K Timer, IO pin or RESETB pin. It takes 100 µs or so to switch from Suspend mode to Active mode. - In Deep sleep with SRAM retention, the PM module is active, analog and digital modules except for the retention SRAMs are powered down, while the retention SRAMs can be retained and not accessible. The chip can be triggered to Active mode by 32K Timer, IO pin or RESETB pin. The time to switch to Active mode is shorter than Deep sleep without SRAM retention and close to Suspend. - In Deep sleep without SRAM retention, only the PM module is active, while analog and digital modules including the retention SRAMs are powered down. The chip can be triggered to Active mode by 32K Timer, IO pin or RESETB pin. The time to switch to Active mode is 1 ms or so. - In Shutdown mode, all digital and analog modules are powered down, and only the PM module is active. The chip can be triggered to Active mode by RESETB pin only. The time to switch to Active mode is 10 ms or so. User can directly invoke corresponding library function to switch working mode of the chip. If certain module doesn't need to work, user can power down this module in order to save power. Table 4-7 3.3 V Analog Register for Module Power up/down Control | Address | R/W | Description | Reset Value | |---------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | Ox4c | R/W | [0] 1: auto power down 32KRC [1] 1:auto power down 32K xtal [2] 1: auto power down bbpll/ temp_sensor [3] 1:auto power down 24M xtal [4] 1:auto power power logic [5] 1:auto power down dcdc [6] 1:auto power down vbus LDO | OxO | | | | [7] 1:auto power down ana LDO | | DS-TLSR9515-E5 62 Ver 0.8.4 | Address | R/W | Description | Reset Value | |---------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | Ox4d | R/W | [0] 1: auto power down low power comparator [1] RSVD [2] RSVD [3] 1:reset xtal quick start cnt [4] 1:auto power suspend Ido [5] 1:auto power retention Ido [6] 1: power down sequence enable [7] 1: enable isolation | OxO | ## 4.5.3 LDO and DCDC The diagram of LDO and DCDC module is shown as following. Figure 4-5 LDO and DCDC As shown in figure above, the SoC embeds two 3.3 V LDO, which can generate 3.3 V voltage output and supply power for Power logic module; one 1.8 V/2.8 V LDO, one 1.8 V/2.8 V DCDC, which can generate 1.8 V/2.8 V voltage output and supply power for Flash and CODEC modules; one 1.4 V LDO/DCDC, which can generate 1.4 V voltage output, one 1.4 V LDO, which can generate 1.4 V voltage as the input of the three 1.2 V LDO; the three 1.2 V LDO can generate 1.2 V voltage output and supply power for RF, Analog, and Digital modules respectively. ## 4.5.4 VBAT and VANT Power-Supply Mode The chip provides two power-supply modes including VBAT mode and VANT mode. - In VBAT mode, the chip is directly supplied with power by its battery voltage. The maximum output power is related to power supply voltage, for example, the maximum power is 10 dBm or so at 3.3 V power supply. - In VANT mode, the chip is supplied with 1.2 V voltage by the embedded DCDC and LDO. In this mode, output power won't change with AVDD basically, and the maximum power is 5 dBm or so. Corresponding to the VBAT mode, the VANT mode is more power-saving at the same TX power. ## 4.6 Charger The SoC supports linear charger function. The charger structure is shown as following: Detector Comparator Comparator Voltage Reference Voltage Reference Voltage Reference Figure 4-6 Charger Diagram As shown in figure above, VUSB is the standard charger port, VBAT is the battery port. The detector detects voltage of VUSB, voltage of VBAT, the total current of VUSB, and the temperature change of the SoC; the detecting results will be transferred to different voltage signals, sent to comparator to compare with reference voltages generated by Voltage Reference Module, the comparison results will be sent to state controller to control the charger core. When VUSB is booting, the charger loops to check whether the values of the detected parameters in the detector exceed the threshold, if yes, the state machine will shut down the charger core and stop charging until the detected parameters return to normal. The thresholds are: - USB port voltage VUSB should be not higher than 5.6 V - Battery voltage VBAT should be not higher than 4.35 V - VBAT should not be higher than VUSB - The total current drawn from USB should be not higher than 120 mA - The SoC temperature should not be higher than 125°C DS-TLSR9515-E5 64 Ver 0.8.4 The charging processing can be divided into 4 stages: - 1. Pre-charging (trickle changing, TC), when the detector detects VBAT is lower than 2.9 V, the charger core will enter the TC working mode, and the charging current is 1/10 of the constant current charging working mode. Constant current and corresponding TC current can be modified by setting register 0x1a<3:0>, the trimming step is 5 mA, the default value of 0x1a<3:0> is 0x1011, the corresponding constant current is 80 mA. - 2. Constant current charging (CC): when VBAT is higher than 2.9 V and lower than 4.2 V, the charger core will enter the CC mode, the charging current will keep to the maximum value, and VBAT increases. - 3. Constant voltage charging (CV): when VBAT reaches 4.2 V the charger core will enter the CV mode, the charging voltage will keep 4.2 V and the charing current will decrease. - 4. End of charging: when the charging current is lower then 1/10 of the CC current, the charging will end. The above is the normal charging process, when then charging ends, and VUSB is still connected, when VBAT is lower then 4.05 V, charger will start working again to repeat the above process, this is recharging. The VBAT timing diagram and charging current timing diagram is shown as below. Figure 4-7 Charging Timing Diagram When ending constant current charging and start constant voltage charging, the changing current will drop to about 1/10 of the former constant charging current, and that is the end current. Please be noted, the values shown in the diagram are theoretical values, the actual constant charging current ranges from 75.83 mA to 81.05 mA, and the actual ending current ranges from 12 mA to 14 mA. DS-TLSR9515-E5 65 Ver 0.8.4 As shown above, the charger is designed for lithium battery (voltage ranges from 3.6 V to 4.2 V). ## 4.7 Wakeup Source Figure below shows wake up sources of the SoC. Figure 4-8 Wake up Sources Each wake up source is detailed below: #### **USB** This wakeup source can only wake up the system from suspend mode. Once USB host sends out resuming signal, the system will be woke up. #### 32 kHZ Timer This wakeup source is able to wake up the system from suspend mode or two deep sleep modes. #### Low Power Comparator This wakeup source is able to wake up the system from suspend mode or two deep sleep modes. #### 10 This wakeup source is able to wake up the system from suspend mode or two deep sleep modes. #### **MDEC** This wakeup source is able to wake up the system from suspend mode or two deep sleep modes. DS-TLSR9515-E5 66 Ver 0.8.4 Table 4-8 Analog Register for Wakeup | Address | R/W | Description | Reset Value | |---------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 0x41 | R/W | wakeup polarity 0: high level<br>wakeup,1: low level wakeup | 0x0 | | 0x42 | R/W | wakeup polarity 0: high level<br>wakeup,1: low level wakeup | OxO | | 0x43 | R/W | wakeup polarity 0: high level<br>wakeup,1: low level wakeup | 0x0 | | 0x44 | R/W | wakeup polarity 0: high level<br>wakeup,1: low level wakeup | 0x0 | | 0x45 | R/W | wakeup polarity 0: high level<br>wakeup,1: low level wakeup | OxO | | 0x46 | R/W | PA wakeup enable | OxO | | 0x47 | R/W | PB wakeup enable | 0x0 | | 0x48 | R/W | PC wakeup enable | 0x0 | | 0x49 | R/W | PD wakeup enable | 0x0 | | 0x4a | R/W | PE wakeup enable | 0x0 | | Ox4b | R/W | [0] dly sel enable, 1:enable delay controller by pad,delay 0xfb.0: disable pad controller dly, delay is controlled by r_dly; [1] RSVD [2] pad wakeup filter, 1:pad wakeup filter enable 0: disable filter [3] pad wakeup enable [4] dig wakeup enable [5] timer wakeup enable [6] comparator wakeup enable | 0x1000000 | | Address | R/W | Description | Reset Value | |---------|-----|-----------------------------------------------------------------------|-------------| | Ox64 | R | write 1 to clean the status: [0]:wkup cmp [1]:wkup timer [2]:wkup dig | - | | | | [3]:wkup pad [4]:wkup mdec [7:5] rsvd | | ## 5 Audio Audio module consists of 3 parts: audio CODEC, audio in path, and audio out path. ## 5.1 Audio CODEC Audio CODEC is shown as following: Figure 5-1 Audio CODEC As shown in the figure above, audio CODEC consists of one stereo Analog to Digital Converter (ADC), one stereo Digital to Analog Converter (DAC), digital filters and data and control interface. ADC supports mono/stereo line-in/AMIC/DMIC as input. Line-in is the default input, the analog boost gain ranges from 0 to 20 dB, with stage of 4 dB, the digital programmable gain ranges from 1 to 43 dB, with stage of 1 dB. #### NOTE: - TLSR9515A supports stereo AMIC/DMIC input - TLSR9515B supports mono AMIC input - TLSR9515D supports mono AMIC/DMIC input To choose AMIC and DMIC path, related register should be configured, please refer to register table. DAC supports stereo differential analog output, with analog programmable gain ranging from -19 to +12 dB, and digital programmable gain from -31 to +32 dB, both gain stages are 1 dB. ## 5.2 Audio-in Path Audio in path is illustrated in figure below. Figure 5-2 Audio in Path As can be seen in figure above, there are 2 audio input sources, i.e., signal via CODEC and USB signal, which can be chosen by configuring registers. Input signal will be produced and then saved in SRAM. ## 5.3 Audio-out Path Audio out path is shown in figure below: DMA SRAM USB Figure 5-3 Audio out Path As shown in figure above, the audio output signals has 2 output channels, i.e., output via CODEC, and USB signal. # 5.4 Register Description Audio path related registers are listed in the table below. The base address for the following registers is 0x80140500. DS-TLSR9515-E5 70 Ver 0.8.4 Table 5-1 Audio Registers | Offset | R/W | Description | Reset Value | |--------|--------|--------------------------------------------------|-------------| | | | [0]:clk_en, i2s clk enable: | | | | | 1'b1: enable | | | | | 1'b0: disable. [1]:clk_div2,i2sclkdivide2enable: | | | | | 1'b1: enable | | | 0x00 | R/W | 1'b0: disable. | 0x00 | | | | [2]: mc_clken, codecmcclkenable: | | | | | 1'b1: enable | | | | | 1'b0: disable. | | | | | [3]:mc_clk_inv_o, codec mc clk invert. | | | | | [1:0]: format | | | | | [3:2]: wl | | | OxO1 | R/W | [4]: lrp | Over | | OXOI | | [5]: Irswap | Охса | | | | [6]: dci_ms | | | | | [7]: bclkinv | | | | | [1:0]: bcm_bits | | | 0x02 | R/W | [2]: bclkinv_o | 0x00 | | | | [3]: rst_fifo | | | | | [1:0]: i2s_cmode | | | 0x03 | R/W | [2]: codec_i2s_sel | 0x00 | | | | [3]: i2s_out_bit_sel | | | | | [1:0]: i2s_ainO_come | | | 0x04 | R/W | [3:2]: i2s_ain1_come | 0x00 | | | | [6:4]: i2s_ain2_come | | | | | [1:0]: ainO_sel | | | OvoE | D //4/ | [3:2]: aoutO_sel | Over | | 0x05 | R/W | [5:4]: ain1_sel | Oxff | | | | [7:6]: aout1_sel | | | 0x08 | R/W | [6:0]: i2c_addr | 0x00 | | 0::0- | D /// | [3:0]: aout0_fifo_trig_num | 047 | | ОхОа | R/W | [7:4]: ainO_fifo_trig_num | 0x17 | | Offset | R/W | Description | Reset Value | |--------|--------|----------------------------|-------------| | 0x0b | R/W | [3:0]: aout1_fifo_trig_num | Ox17 | | 0.00 | IX/ VV | [7:4]: ain1_fifo_trig_num | 0.17 | | 0x0c | R/W | [3:0]: aout0_fifo_num | 0x00 | | OxOd | R/W | [3:0]: ainO_fifo_num | 0x00 | | 0x0e | R/W | [3:0]: aout1_fifo_num | 0x00 | | 0x0f | R/W | [3:0]: ain1_fifo_num | 0x00 | | 0x10 | R/W | [0]: tx_ptr_sel | 0x00 | | Oxio | K/ VV | [4]: rx_ptr_sel | OxOO | | | | [0]: tx_wptr_en | | | 0x11 | R/W | [1]: tx_rptr_en | OxOf | | | ŕ | [2]: rx_wptr_en | | | | | [3]: rx_rptr_en | | | Ox1f | R/W | [0]: txfifo_empty | 0x03 | | OXII | 1() ** | [1]: rxfifo_empty | 0.03 | | 0x20 | R/W | [7:2]: tx_wptr0 | 0x00 | | 0x21 | R/W | [5:0]: tx_wptr1 | 0x00 | | 0x22 | R/W | [7:2]: tx_rptr0 | 0x00 | | 0x23 | R/W | [5:0]: tx_rptr1 | 0x00 | | 0x24 | R/W | [7:0]: txfifo_num0 | 0x00 | | 0x25 | R/W | [5:0]: txfifo_num1 | 0x00 | | 0x26 | R/W | [7:0]: tx_max0l | 0x00 | | 0x27 | R/W | [5:0]: tx_max0h | 0x00 | | 0x28 | R/W | [7:2]: rx_wptr0 | 0x00 | | 0x29 | R/W | [5:0]: rx_wptr1 | 0x00 | | 0x2ə | R/W | [7:2]: rx_rptr0 | 0x00 | | 0x2b | R/W | [5:0]: rx_rptr1 | 0x00 | | 0x2c | R/W | [7:0]: rxfifo_num0 | 0x00 | | 0x2d | R/W | [5:0]: rxfifo_num1 | 0x00 | | 0x2e | R/W | [7:0]: rx_max0l | 0x00 | | Offset | R/W | Description | Reset Value | |--------|-----|-----------------------|-------------| | 0x2f | R/W | [5:0]: rx_max0h | 0x00 | | 0x30 | R/W | [7:0]: thd0_h_l1_l | 0x00 | | 0x31 | R/W | [5:0]: thd0_h_l1_h | 0x00 | | 0x32 | R/W | [7:0]: thd0_l_l1_l | 0x00 | | 0x33 | R/W | [5:0]: thd0_l_l1_h | 0x00 | | 0x34 | R/W | [3:0]: i2s_dactune_l1 | 0x00 | | 0x38 | R/W | [7:0]: thd0_h_l2_l | 0x00 | | 0x39 | R/W | [5:0]: thd0_h_l2_h | 0x00 | | 0x3a | R/W | [7:0]: thd0_l_l2_l | 0x00 | | 0x3b | R/W | [5:0]: thd0_l_l2_h | 0x00 | | Ох3с | R/W | [3:0]: i2s_dactune_l2 | 0x00 | | 0x40 | R/W | [7:0]: thd1_h_l1_l | 0x00 | | 0x41 | R/W | [5:0]: thd1_h_l1_h | 0x00 | | 0x42 | R/W | [7:0]: thd1_l_l1_l | 0x00 | | 0x43 | R/W | [5:0]: thd1_l_l1_h | 0x00 | | 0x44 | R/W | [3:0]: i2s_adctune_l1 | 0x00 | | 0x48 | R/W | [7:0]: thd1_h_l2_l | 0x00 | | 0x49 | R/W | [5:0]: thd1_h_l2_h | 0x00 | | 0x4a | R/W | [7:0]: thd1_l_l2_l | 0x00 | | 0x4b | R/W | [5:0]: thd1_l_l2_h | 0x00 | | 0x4c | R/W | [3:0]: i2s_adctune_l2 | 0x00 | | 0x50 | R/W | [7:0]: int_pcm_num0 | 0x00 | | 0x51 | R/W | [4:0]: int_pcm_num1 | 0x00 | | 0x52 | R/W | [7:0]: dec_pcm_num0 | 0x00 | | 0x53 | R/W | [4:0]: dec_pcm_num1 | 0x00 | | 0x54 | R/W | [3:0]: pcm_clk_num | 0x00 | | Offset | R/W | Description | Reset Value | |--------|-----|--------------------------------------------------------------------------------------------|-------------| | 0x58 | R/W | [0]: codec_mbist_mode [1]: codec_mbist_start [2]: codec_mbist_srstn [3]: codec_mbist_clken | 0x00 | | 0x59 | R/W | [0]: codec_mbist_end_i [1]: codec_mbist_fail_i [2]: codec_mbist_ferr_i | 0x00 | | 0x5a | R/W | [2:0]: codec_mbist_clkdiv | 0x00 | ## 6 BT/BLE RF Transceiver ## 6.1 Overview The SoC integrates an advanced RF transceiver for 5.2 Dual-Mode (BLE + BR/EDR) application. This RF transceiver works in the worldwide 2.4GHz ISM band and it consists of a fully integrated RF synthesizer, a Power Amplifier (PA), a Low Noise Amplifier (LNA), a TX LPF, a Rx complex filter, a TX DAC, a RX ADC, BLE/BT modulator/Demodulator and on-chip balun. The Classic Bluetooth mode works in standard-compliant BR mode/EDR2 mode and EDR3 mode. The BLE mode works in standard-compliant 1Mbps BLE mode, 2Mbps enhancement BLE mode,125Kbps BLE long range mode(S8), 500kbps BLE long range mode(S2). The block digram of the transceiver is shown below. Complex filter Rx Mixer Rx\_LO\_I ANT Rx LO Q Balun Rx\_LO\_I < /2 Bluetooth Rx\_LO\_Q ◀ BLE /BLE Modem Modulation Data Tx\_LO\_I PLL frequency /2 Tx\_LO\_Q synthersizer BLE L x\_LO\_I Tx\_LO\_Q Tx LPF Figure 6-1 Block Diagram of RF Transceiver ## 6.2 Air Interface Data Rate and RF Channel Frequency Air interface data rate, the modulated signaling rate for RF transceiver when transmitting and receiving data, is configurable via related register setting: 125kbps, 250kbps, 500kbps, 1Mbps, 2Mbps, 3Mbps. RF transceiver can operate with frequency ranging from 2.400GHz to 2.4835GHz. The RF channel frequency setting determines the center of the channel. DS-TLSR9515-E5 75 Ver 0.8.4 ## 6.3 Baseband The baseband is disabled by default. The corresponding API is available for user to power on/down the baseband and enable/disable clock, so that the baseband can be turned on/off flexibly. The baseband contains dedicated hardware logic to perform fast AGC control, access code correlation, CRC checking, data whitening, encryption/decryption and frequency hopping logic. The baseband supports all features required by Bluetooth 5 specification. #### 6.3.1 Packet Format Packet format in standard 1 Mbps BLE mode is shown in table below. Table 6-1 Packet Format in Standard 1 Mbps BLE Mode LSB MSB | Preamble | Access Address | PDU | CRC | |-----------|----------------|------------------|------------| | (1 octet) | (4 octets) | (2 ~ 257 octets) | (3 octets) | Packet length 80 bit $\sim$ 2120 bit (80 $\sim$ 2120 $\mu$ s @ 1 Mbps). Packet format in standard 2 Mbps BLE mode is shown in table below. Table 6-2 Packet Format in Standard 2 Mbps BLE Mode LSB MSB | Preamble | Access Address | PDU | CRC | |-----------|----------------|------------------|------------| | (2 octet) | (4 octets) | (2 ~ 257 octets) | (3 octets) | Packet length 44 bit $\sim$ 1064 bit (44 $\sim$ 1064 $\mu$ s @ 2 Mbps). Packet format in standard 500kbps/125kbps BLE mode is shown in table below. Table 6-3 Packet Format in Standard 500 kbps/125 kbps BLE Mode LSB MSB | Preamble Addre (10 octet) (4 oct | ss (2 bits) | TERM1<br>(3 bits) | PDU<br>(2 ~ 257<br>octets) | CRC<br>(3 octets) | TERM2<br>(3 bits) | |----------------------------------|-------------|-------------------|----------------------------|-------------------|-------------------| |----------------------------------|-------------|-------------------|----------------------------|-------------------|-------------------| Packet format of Basic Rate Packet is shown in table below. Table 6-4 Packet Format of Basic Rate Packets | LSB 68/72 | 54 | 0~2790 MSB | |-------------|--------|------------| | Access Code | Header | Payload | Packet format of Enhanced Data Rate Packets is shown in table below. #### Table 6-5 Packet Format of Enhanced Data Rate Packet LSB MSB | Access Code | Header | Guard | SYNC | Enhanced Data<br>Rate Payload | Trailer | |-------------|--------|-------|------|-------------------------------|---------| | | GFSK | | | DPSK | | #### 6.3.2 BLE Location Function #### NOTE: BLE location function is available only on TLSR9515D In BLE 1M or 2M mode, BLE location features including AoA (Angel of Arrival) and AoD (Angle of Departure) are supported. In the location mode of operation, the chip transmits a training sequence concatenated to the normal packet transmissions. In AoA mode of operation, the receiving side has multiple antennas and will be switched during the training sequence period. In AoD mode of operation, the transmitting side has multiple antennas and will be switched during the training sequence period. In either mode, the receiving side will be able to determine based on the phase variations of the received training sequences, the angle of location of the peer device. #### 6.3.3 RSSI and Frequency Offset The SoC provides accurate RSSI (Receiver Signal Strength Indicator) and frequency offset indication. - RSSI can be read from the 1 byte at the tail of each received data packet. - If no data packet is received (e.g. to perform channel energy measurement when no desired signal is present), real-time RSSI can also be read from specific registers which will be updated automatically. - RSSI monitoring resolution can reach +/-1 dB. - Frequency offset can be read from the 2 bytes at the tail of the data packet. Valid bits of actual frequency offset may be less than 16 bits, and different valid bits correspond to different tolerance range. Telink supplies corresponding drivers for user to read RSSI and frequency offset as needed. DS-TLSR9515-E5 77 Ver 0.8.4 # 7 Clock ## 7.1 Clock Sources The SoC's clock sources are a 24 MHz RC oscillator, an clk\_eoc module, and an external 24 MHz crystal, as shown below. Figure 7-1 Clock Source The clock sources of each module is shown in table below. Table 7-1 Clock Sources of Each Module | Module | Clock Source(s) | |---------|----------------------------------| | HSPI | hclk | | I2C | pclk | | UARTO | pclk | | USB | hclk, clk_usb | | PWM | pclk, clk32k | | UART1 | pclk | | SWIRE | hclk | | STIMER | pclk, clk32k, clk_stimer | | DMA | hclk | | ALGM | pclk | | PKE | hclk | | PLMT | clk32k, hclk | | PSPI | pclk | | SPI_SLV | hclk | | TIMER | pclk | | AUDIO | hclk, clk_i2s | | TRNG | hclk | | MCU | cclk | | LM | cclk | | ZB | pclk, clkzb32k, clk_zb_mst, hclk | | EOC | clk_eoc_src, pclk | | GPIO | pclk | | MSPI | hclk, pclk, clk_mspi | | CODEC | clk_dmic | ## 7.2 System Clock There are five selectable clock sources for MCU system clock: RC\_24M derived from 24 MHz RC oscillator, 24M crystal, sclk\_div, pll clk and clk\_eoc. The sources are selectable via register CLKSELO. ### 7.3 Module Clock Registers CLKENO~CLKEN3 are used to enable or disable clock for various modules. By disable the clocks of unused modules, current consumption could be reduced. ### 7.3.1 System Timer Clock System timer clock is derived from 24M crystal oscillator via a 2/3 frequency divider. The clock frequency is fixed as 16MHz. #### 7.3.2 USB Clock USB clock is generated by pll\_clk via frequency divider, the frequency is calculated with the following equations: $Fclk_usb = Fpllclk/n (n=0x801401fb[2:0], n=2~7)$ $Fclk_usb = Fpllclk/16 (n=0x801401fb[2:0], n=0)$ #### 7.3.3 DMIC Clock DMIC clock is derived from pllclk via a frequency divider. Register DMIC\_STEP should be set as 1'b1 to enable DMIC clock. DMIC clock frequency dividing factor contains step and mod. Register DMIC\_STEP and DMIC\_MOD serve to set DMIC clock step[6:0] and mod[7:0] respectively, and mod should be no less than 2\*step. DMIC clock frequency, Fdmic\_clock, equals to pllclk\*DMIC\_step[6:0]/l2S\_mod[7:0]. #### 7.3.4 clkzb32k When $CLK_DIV[0] = 1$ , $Fclkzb32k=Fpad_24m/1500$ ; when $CLK_DIV[0] = 0$ , $Fclkzb32k=Fpad_24m/700$ ; when register $CLK_DIV[1] = 1$ , clkzb32k chooses clk32k, when $CLK_DIV[1] = 0$ , clkzb32 chooses the clock generated by $pad_24M$ via a frequency divider. ## 7.3.5 clk\_7816 $Fclk_7816 = Fpad_24m/n (n=CLK_DIV[6:4], n=2~7)$ $Fclk_7816 = Fpad_24m/16 (n=CLK_DIV[6:4], n=0)$ ## 7.3.6 clk\_eoc\_src clk\_eoc\_src is the system clock of eoc module. When register SEL[1] = 1, clk\_eco\_src = pllclk, when register SEL[1] = 0, clk\_eco\_src = pllclk\_div. ## $7.3.7 \ clk\_zb\_mst$ clk\_zb\_mst is generated by hclk via frequency divider. $Fclk_zb_mst = Fhclk/(n+1) (n=CLKEN3[3:0], n=0~15).$ ## 7.3.8 clk\_mspi clk\_mspi is the system clock of MSPI module. The default value of CLKSELO[7] is 1, and clk\_mspi chooses sys\_clk, Fclk\_mspi = Fpllclk/n (n=CLKSEL1[7:4], n= $2\sim15$ ); $Fclk_usb = Fpllclk/32 (n=CLKSEL1[7:4], n=0).$ ## 7.4 Register Table Clock related registers are listed in table below. The base address of the following registers is 0x1401c0. Table 7-2 Clock Related Registers | Address | R/W | Description | Reset Value | |---------|-----|-----------------------------------------------------------------------------------------|-------------| | 0x12 | R/W | CLKMOD [3:0]: zb_mst_mod [7:4]: clknpe_mod | Oxa3 | | 0x24 | R/W | CLKENO [0]: hspi [1]: i2c [2]: uartO [3]: usb [4]: pwmO [5]: reserved [6]: uart1 [7]: - | 0x80 | DS-TLSR9515-E5 81 Ver 0.8.4 | Address | R/W | Description | Reset Value | |---------|-----|------------------------------------------------------------------------|-------------| | | | CLKEN1 | | | | | [O]:reserved | | | | | [1]:stimer | | | | | [2]:dma | | | 0x25 | R/W | [3]:algm | 0ex0 | | | | [4]:pke | | | | | [5]:machinetime | | | | | [6]:pspi | | | | | [7]:spislv- | | | | | CLKEN2 | | | | | [O]:timer | | | | | [1]:audio | | | 0x26 | R/W | [2]:trng | 0x30 | | | | [4]:mcu | | | | | [5]:lm | | | | | [7]:eoc | | | | - 4 | CLKEN3 | | | 0x27 | R/W | [0:3]:clk_zb_mst | 0x00 | | | | CLKSELO [3:0]:sclk_div [6:4]:sclk_sel, 000:24M_rc, | | | 0x28 | R/W | 001:24M xtal, 010:sclk_div, 011:pll clk, 110:clk_eoc [7]: mspi_clk_sel | 0x02 | | 0x29 | R/W | CLKSEL1 [7:4]:mspi_div | 0x20 | | Ox2a | R/W | | 0x01 | | 0x2b | R/W | r_i2s_mod_o | 0x02 | | Address | R/W | Description | Reset Value | |---------|-----|--------------------------------------------------------------------------------------------|-------------| | 0x2c | R/W | DMIC_STEP [6:0]:dmic_step [7]: dmic_clk_sel | 0x01 | | 0x2d | R/W | DMIC_MOD | OxO2 | | Ox2e | R/W | WAKEUPEN [0]: usb_pwdn_i [1]: gpio_wakeup_i [2]: usb resume [3]: standby ex [7:4]:reserved | Ox1f | | 0x2f | R/W | PWDNEN [0]: suspend_en_o [4]: ramcrc_clren_tgl [5]: rst_cnt [7]: stall_en_trg | 0x00 | | 0x30 | R/W | CLK_DIV<br>[0:2]: clkzb32k_sel<br>[6:4]: r_7816_mod | Ox62 | | 0x33 | R/W | SEL [0]: r_dmic_sel_o, 0:dmic_div 1:32k [1]: r_eco_clk_sel_o | 0x00 | ## 8 Timer ## 8.1 Timer0 ~ Timer1 The SoC supports two timers: Timer0 ~ Timer1. Timer0 and Timer1 support four modes: Mode 0 (System Clock Mode), Mode 1 (GPIO Trigger Mode), Mode 2 (GPIO Pulse Width Mode) and Mode 3 (Tick Mode), which are selectable via the register TMR\_CTRL0 (address 0x140140). The SoC supports one watchdog timer. The MCU of the SoC embeds a machine timer, using 32K system clock, the address of which is 0xE6000000~0xE60FFFFF. ### 8.1.1 Mode 0 (System Clock Mode) In Mode O, system clock is employed as clock source. After Timer is enabled, Timer Tick (i.e. counting value) is increased by 1 on each positive edge of system clock from preset initial Tick value. Generally the initial Tick value is set to 0. Once current Timer Tick value matches the preset Timer Capture (i.e. timing value), an interrupt is generated, Timer stops counting and Timer status is updated. Steps of setting TimerO for Mode O is taken as an example. #### Step 1. Set initial Tick value of TimerO Set Initial value of Tick via registers TMR\_TICKO\_0~TMR\_TICKO\_3, from lowest byte to highest byte respectively. It's recommended to clear initial Timer Tick value to 0. #### Step 2. Set Capture value of TimerO Set registers TMR\_CAPTO\_0~TMR\_CAPTO\_3, from lowest byte to highest byte respectively. #### Step 3. Set TimerO to Mode O and enable TimerO Set register TMR\_CTRLO [2:1] to 2b'00 to select Mode 0; Meanwhile set TMR\_CTRLO [0] to 1b'1 to enable TimerO. TimerO starts counting upward, and Tick value is increased by 1 on each positive edge of system clock until it reaches TimerO Capture value. ## 8.1.2 Mode 1 (GPIO Trigger Mode) In Mode 1, GPIO is employed as clock source. The "m0"/"m1"/"m2" register specifies the GPIO which generates counting signal for Timer0/Timer1/Timer2. After Timer is enabled, Timer Tick (i.e. counting value) is increased by 1 on each positive/negative (configurable) edge of GPIO from preset initial Tick value. Generally the initial Tick value is set to 0. The "Polarity" register specifies the GPIO edge when Timer Tick counting increases. Once current Timer Tick value matches the preset Timer Capture (i.e. timing value), an interrupt is generated and timer stops counting. Steps of setting Timer1 for Mode 1 is taken as an example. #### Step 1. Set initial Tick value of Timer1 Set Initial value of Tick via registers TMR\_TICK1\_0~TMR\_TICK1\_3, from lowest byte to highest byte respectively. It's recommended to clear initial Timer Tick value to 0. #### Step 2. Set Capture value of Timer1 Set registers TMR\_CAPT1\_0~TMR\_CAPT1\_3, from lowest byte to highest byte respectively. #### Step 3. Select GPIO source and edge for Timer1 Select certain GPIO to be the clock source via setting "m1" register. Select positive edge or negative edge of GPIO input to trigger Timer1 Tick increment via setting "Polarity" register. #### Step 4. Set Timer1 to Mode 1 and enable Timer1 Set TMR\_CTRLO [5:4] to 2b'01 to select Mode 1; Meanwhile set TMR\_CTRLO [3] to 1b'1 to enable Timer1. Timer1 starts counting upward, and Timer1 Tick value is increased by 1 on each positive/negative (specified during the 3<sup>rd</sup> step) edge of GPIO until it reaches Timer1 Capture value. ### 8.1.3 Mode 2 (GPIO Pulse Width Mode) In Mode 2, system clock is employed as the unit to measure the width of GPIO pulse. The "m0"/"m1"/"m2" register specifies the GPIO which generates control signal for Timer0/Timer1/Timer2. After Timer is enabled, Timer Tick is triggered by a positive/negative (configurable) edge of GPIO pulse. Then Timer Tick (i.e. counting value) is increased by 1 on each positive edge of system clock from preset initial Tick value. Generally the initial Tick value is set to 0. The "**Polarity**" register specifies the GPIO edge when Timer Tick starts counting. While a negative/positive edge of GPIO pulse is detected, an interrupt is generated and timer stops counting. The GPIO pulse width could be calculated in terms of tick count and period of system clock. Steps of setting Timer1 for Mode 2 is taken as an example. #### Step 1. Set initial Timer1 Tick value Set Initial value of Tick via registers TMR\_TICK1\_0~TMR\_TICK1\_3, from lowest byte to highest byte respectively. It's recommended to clear initial Timer Tick value to 0. #### Step 2. Select GPIO source and edge for Timer1 Select certain GPIO to be the clock source via setting "m1" register. Select positive edge or negative edge of GPIO input to trigger Timer2 counting start via setting "Polarity" register. #### Step 3. Set Timer2 to Mode 2 and enable Timer1 Timer1 Tick is triggered by a positive/negative (specified during the 2<sup>nd</sup> step) edge of GPIO pulse. Timer1 starts counting upward and Timer1 Tick value is increased by 1 on each positive edge of system clock. While a negative/positive edge of GPIO pulse is detected, an interrupt is generated and Timer1 tick stops. #### Step 4. Read current Timer1 Tick value to calculate GPIO pulse width Read current Timer1 Tick value. Then GPIO pulse width is calculated as follows: GPIO Pulse Width = System Clock Period \*(Current Timer1 Tick - Initial Timer1 Tick) For initial Timer1 Tick value is set to the recommended value of 0, then: GPIO Pulse Width = System Clock Period \* Current Timer1 Tick ### 8.1.4 Mode 3 (Tick Mode) In Mode 3, system clock is employed. After Timer is enabled, Timer Tick starts counting upward, and Timer Tick value is increased by 1 on each positive edge of system clock. This mode could be used as time indicator. There will be no interrupt generated. Timer Tick keeps rolling from 0 to 0xffffffff. When Timer tick overflows, it returns to 0 and starts counting upward again. Steps of setting TimerO for Mode 3 is taken as an example. #### Step 1. Set initial Tick value of TimerO Set Initial value of Tick via TMR\_TICKO\_1 ~TMR\_TICKO\_3, from lowest byte to highest byte respectively. #### Step 2. Set TimerO to Mode 3 and enable TimerO Set TMR\_CTRLO [2:1] to 2b'11 to select Mode 3, meanwhile set address TMR\_CTRLO [0] to 1b'1 to enable TimerO. TimerO Tick starts to roll. #### Step 3. Read current TimerO Tick value Current Timer0 Tick value can be read fromTMR\_TICKO\_1 ~TMR\_TICKO\_3. ### 8.1.5 Watchdog Programmable watchdog could reset chip from unexpected hang up or malfunction. Watchdog Capture has 24bits, which consists of WT\_TARGET\_1~WT\_TARGET\_3 as byte 1 ~byte 3. Chip will be reset when TMR\_CTRL3[3] is set to 1. #### Step 1. Set WT\_TARGET\_1~WT\_TARGET\_3 Set registers WT\_TARGET\_1~WT\_TARGET\_3, from lowest byte to highest byte respectively. #### Step 2. Enable Watchdog Set TMR\_CTRL2 [7] to 1b'1 to enable Watchdog. During normal working condition, TMR\_CTRL3[3] need write 1 to clean the watchdog before the watchdog hits WT\_TARGET3-1, or it will reboot the whole chip, and the TMR\_CTRL3[2] will be assert to 1, this bit will be clean when write 1. DS-TLSR9515-E5 86 Ver 0.8.4 ## 8.1.6 Register Table Timer related register are listed in table below. The base address for the following registers is 0x 140140. Table 8-1 Register Configuration for Timer 0 ~ Timer 1 | Offset | R/W | Description | Reset Value | |--------|----------------|---------------------------------------|-------------| | | | TMR_CTRL0 | | | | | [1:0] O:tmrOmO,using pclk 1:tmrOm1, | | | | | count gpio2risc0 posedge 2:tmr0m2 | | | | | count gpio2riscO high width | | | | | 3:tmr0m3,tick | | | | | [2] TimerO enable | | | 0x00 | R/W | [3] TimerO nowrap | 0x0 | | | | [5:4] 0:tmr1m0,using pclk 1:tmr1m1, | | | | | count gpio2risc1 posedge 2:tmr1m2 | | | | | count gpio2risc1 high width | | | | | 3:tmr1m3,tick | | | | | [6] Timer2 enable | | | | | [7] Timer1 nowrap | | | 0x02 | R/W | TMR_CTRL2 | 0x0 | | UXUZ | R/VV | [7] watchdog_en | OXO | | | | TMR_CTRL3 | | | | | [O] tmrO_o=tmrO | | | | | [1] tmr1_o=tmr1 | | | 0x03 | R/W | [2] hit watchdog target | 0x0 | | | | [3] clear wd_cnt | | | | | [7] software_irq | | | | - 4 - 1 | TMR_CAPTO_0 | | | 0x04 | R/W | capt0[7:0] Byte 0 of timer0 capture | 0x0 | | | | TMR_CAPTO_1 | | | 0x05 | R/W | capt0[15:8] Byte 1 of timer0 capture | 0x0 | | | | TMR_CAPTO_2 | | | 0x06 | R/W | capt0[23:16] Byte 2 of timer0 capture | 0x0 | | | <b>=</b> 6 · · | TMR_CAPTO_3 | | | 0x07 | R/W | capt0[31:24] Byte 3 of timer0 capture | 0x0 | | 0.00 | - / | TMR_CAPT1_0 | | | 80x0 | R/W | capt1[7:0] Byte 0 of timer1 capture | 0x0 | | Offset | R/W | Description | Reset Value | |--------|-----|---------------------------------------------------------------------|-------------| | 0x09 | R/W | TMR_CAPT1_1 capt1[15:8] Byte 1 of timer1 capture | 0x0 | | 0x0a | R/W | TMR_CAPT1_2 capt1[23:16] Byte 2 of timer1 capture | 0x0 | | 0x0b | R/W | TMR_CAPT1_3 capt1[31:24] Byte 3 of timer1 capture | 0x0 | | OxOd | R/W | WT_TARGET_1 watchdog_target2[15:8] Byte 1 of watchdog target value | 0x0 | | 0x0e | R/W | WT_TARGET_2 watchdog_target2[23:16] Byte 2 of watchdog target value | 0x0 | | OxOf | R/W | WT_TARGET_3 watchdog_target2[31:24] Byte 3 of watchdog target value | 0x0 | | 0x10 | R | TMR_TICKO_0 ticko[7:0] Byte 0 of timer0 ticker | 0x0 | | Ox11 | R | TMR_TICKO_1 ticko[15:8] Byte 1 of timerO ticker | OxO | | 0x12 | R | TMR_TICKO_2 ticko[23:16] Byte 2 of timerO ticker | OxO | | 0x13 | R | TMR_TICKO_3 ticko[31:24] Byte 3 of timerO ticker | 0x0 | | 0x14 | R | TMR_TICK1_0 tick1[7:0] Byte 0 of timer1 ticker | 0x0 | | 0x15 | R | TMR_TICK1_1 tick1[15:8] Byte 1 of timer1 ticker | 0x0 | | 0x16 | R | TMR_TICK1_2<br>tick1[23:16] Byte 2 of timer1 ticker | 0x0 | | 0x17 | R | TMR_TICK1_3<br>tick1[31:24] Byte 3 of timer1 ticker | 0x0 | ## 8.2 32K LTimer The SoC also supports a low frequency (32kHz) LTIMER in suspend mode or deep sleep mode. This timer can be used as one kind of wakeup source. ## 8.3 System Timer The SoC also supports a System Timer, the clock frequency for System Timer is fixed as 16MHz irrespective of system clock. In suspend mode, both System Timer and TimerO ~ Timer1 stop counting, and 32K Timer starts counting. When the chip restores to active mode, TimerO ~ Timer1 will continue counting from the number when they stops; In contrast, System Timer will continue counting from an adjusted number which is a sum of the number when it stops and an offset calculated from the counting value of 32K Timer during suspend mode. System timer related registers are listed in table below. The base address for the registers is 0x140200. Table 8-2 Register Table for System Timer | Offset | R/W | Description | Reset Value | |--------|-----|----------------|-------------| | 0x00 | R/W | SYS_TIMERO | OxO | | 0x01 | R/W | SYS_TIMER1 | OxO | | 0x02 | R/W | SYS_TIMER2 | OxO | | 0x03 | R/W | SYS_TIMER3 | OxO | | ОхОа | R/W | SYS_TIMER_CTRL | OxO | | OxOb | R/W | SYS_TIMER_ST | OxO | # 9 Interrupt System ## 9.1 Interrupt Structure The SoC provides three interrupt inputs: Timer interrupt, software interrupt, and external interrupt. External interrupts are arbitrated and distributed by a platform-level interrupt controller (PLIC) to the processor core. Each external interrupt source can be assigned its own priority, and the RISC-V processor core could select which external interrupt sources it would handle. PLIC routes the highest priority interrupt source to the target processor. The Machine Interrupt Pending Control and State Register (MIP CSR) contains pending bits of these three interrupts, and the Machine Interrupt Enable Control and State Register (MIE CSR) contains enable bits of these interrupts. The processor can selectively enable interrupts by manipulating the MIE CSR, or globally disable interrupts by clearing the MIE bit. Platform-Level Interrupt Controller (PLIC) prioritizes and distributes global interrupts. It is compatible with RISC-V PLIC with the following features: - Software-programmable interrupt generation - Preemptive priority interrupt extension - Vectored interrupt extension The following figure shows the block diagram of PLIC. Interrupt source (e.g., devices) send interrupt requests to PLIC through the int\_src signals and they are converted to interrupt requests by the interrupt gateway. Interrupt requests are prioritized and routed to interrupt targets (e.g., RISC-V processor core) according to interrupt settings. Interrupt settings include enable bits, priorities, and priority thresholds, and these settings are programmable through the bus interface. Figure 9-1 Block Diagram of PLIC # 9.2 External Interrupt Sources There are 63 external interrupt sources, listed in table below. Table 9-1 Interrupt Sources | No. | Туре | Interrupt Source | | | | |-----|------|------------------|--|--|--| | 1 | syn | irq_stimer_lev | | | | | 2 | syn | alg_irq | | | | | 3 | syn | tmr1_irq | | | | | 4 | syn | tmr0_irq | | | | | 5 | syn | irq_dma | | | | | 6 | syn | irq_bmc | | | | | 7 | syn | irq_udc_[0] | | | | | 8 | syn | irq_udc[1] | | | | | 9 | syn | irq_udc[2] | | | | | 10 | syn | irq_udc[3] | | | | | 11 | syn | irq_udc[4] | | | | | 12 | syn | irq_zb_dm | | | | | 13 | syn | irq_zb_ble | | | | | 14 | syn | irq_zb_bt | | | | | 15 | syn | irq_zb_rt | | | | | 16 | syn | irq_pwm | | | | | 17 | syn | irq_pke | | | | | 18 | syn | irq_uart1 | | | | | 19 | syn | irq_uart | | | | | 20 | syn | irq_dfifo | | | | | 21 | syn | irq_i2c | | | | | 22 | syn | irq_spi_ahb | | | | | 23 | syn | irq_spi_apb | | | | | 24 | syn | usb_pwdn | | | | | 25 | syn | irq_gpio | | | | | No. | Туре | Interrupt Source | |-----|------|------------------| | 26 | syn | gpio2risc[0] | | 27 | syn | gpio2risc[1] | | 28 | syn | soft_irq | | 29 | syn | - | | 30 | syn | - | | 31 | syn | - | | 32 | syn | - | | 33 | syn | - | | 34 | syn | usb_250us | | 35 | syn | usb_reset | | 36 | syn | - | | 37 | syn | - | | 38 | syn | - | | 39 | syn | - | | 40 | syn | - | | 41 | syn | - | | 42 | syn | - | | 43 | syn | - | | 44 | syn | - | | 45 | syn | - | | 46 | syn | - | | 47 | syn | - | | 48 | syn | - | | 49 | syn | - | | 50 | syn | - | | 51 | syn | - | | 52 | syn | - | | 53 | syn | - | | No. | Туре | Interrupt Source | |-----|------|------------------| | 54 | syn | - | | 55 | syn | - | | 56 | syn | - | | 57 | syn | - | | 58 | syn | - | | 59 | syn | - | | 60 | syn | - | | 61 | asyn | - | | 62 | asyn | pm_irq_tm | | 63 | asyn | emq_irq | # 9.3 Register Description PLIC related register are listed in table below. The base address for the following registers is 0xE4000000. Table 9-2 Register Configuration for PLIC | Offset | R/W | Description | Reset Value | |--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 0x00 | R/W | Feature Enable Register [0]: PREEMPT, Preemptive priority interrupt enable [1]: VECTORED, Vector mode enable | 0x00 | | 0x04*n | R/W | Interrupt Source n Priority [31:0]: Interrupt source n priority. O: Never interrupt, 1-3: Interrupt source priority. The larger the value, the higher the priority. | 0x01 | | Offset | R/W | Description | Reset Value | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 0x1000 | Interrupt source 1~31 Pending. The register provide the interrupt pending status of interrupt sources 1 and a way for software to Ox1000 R/W trigger an interrupt without relying of external devices. Every interrupt sour occupies 1 bit. [31:1]: interrupt pending status of interrupt sources 1~31. | | 0x00 | | 0x1004 | R/W | Interrupt source 32~63 Pending. The register provide the interrupt pending status of interrupt sources 32~63, and a way for software to trigger an interrupt without relying on external devices. Every interrupt source occupies 1 bit. [31:0]: interrupt pending status of interrupt sources 32~63. | 0x00 | | 0x1080 | Interrupt Trigger Type. These registers are read-only and indicate the configured interrupt trigge type of interrupt sources 1~31. Every | | 0x00 | | 0x1084 | R/O | Interrupt Trigger Type. These registers are read-only and indicate the configured interrupt trigger type of interrupt sources 32~63. Every interrupt source occupies 1 bit. [31:0]: Edge-triggered interrupt, 1: Edge-triggered interrupt, O: Level-triggered interrupt | 0x00 | | Offset | Offset R/W Description | | Reset Value | | |----------|------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--| | 0x1100 | Number of Interrupt and Target Configuration Register. [15:0]: The number of supported interrupt sources [31:16]: The number of supported targets | | 0x0002003F | | | 0x1104 | R/O | Version & Maximum Priority Configuration Register. [15:0]: The version of the PLIC design [31:16]: The maximum priority supported | 0x00030001 | | | 0x2000 | R/W | Interrupt Enable Bits for interrupt sources 1~31. Every interrupt source occupies 1 bit. [31:1]: Interrupt Enable Bits for interrupt sources 1~31 | 0x00 | | | 0x2004 | R/W | Interrupt Enable Bits for interrupt sources 32~63. Every interrupt source occupies 1 bit. [31:0]: Interrupt Enable Bits for interrupt sources 32~63. | 0x00 | | | 0x200000 | R/W | Priority Threshold. [31:0]: THRESHOLD, Interrupt priority threshold | 0x0 | | | 0x200004 | R/W | Claim and Complete Register. [9:0]: INTERRUPT_ID, On reads, indicating the interrupt source that has being claimed. On writes, indicating the interrupt source that has been handled (completed). | 0x0 | | | Offset | R/W | Description | Reset Value | |----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------| | 0x200400 | R/W | The register is read/writable registers for accessing the preempted priority stack. The purpose of the register is for saving and restoring priorities of the nested/ preempted interrupts. [3:0]: Each bit indicates if the corresponding priority level has been preempted by a higher-priority interrupt. | 0x00 | # 10 Interface ## 10.1 GPIO TLSR9515D supports up to 27 GPIOs, TLSR9515A/B supports up to 15 GPIOs. All digital IOs can be used as general purpose IOs. ## 10.1.1 Basic Configuration All GPIOs can be configured with related registers, as described as following. Table 10-1 GPIO Pad Function Mux | Pad | Default | Register = 3 | Register = 2 | Register = 1 | Register = 0 | Register | |-------|------------|--------------|-----------------------------|--------------|---------------------------------|-------------------| | PA[0] | GPIO | - | CLK32K | CLK_7816 | I2S_CLK | 0x140330<br>[1:0] | | PA[1] | SPI_SLV_CN | - | HSPI_CN_IO/<br>DAC_I_DATO_I | UARTO_CTS_I | SPI_SLV_CN_I | 0x140330<br>[3:2] | | PA[3] | SPI_SLV_DI | - | HSPI_MISO_IO/<br>ADC_I_DAT2 | UARTO_TX | SPI_SLV_DI_IO | 0x140330<br>[7:6] | | PA[5] | GPIO | - | DAC_I_DAT1_I | - | DM_IO | 0x140331<br>[3:2] | | PA[6] | GPIO | - | DAC_Q_DAT1_I | - | DP_IO | 0x140331<br>[5:4] | | PA[7] | SWS_IO | - | - | - | SWS_IO | 0x140331<br>[7:6] | | PB[0] | GPIO | - | PWM5_O/<br>TX_EN_I | TX_CYC2PA | HSPI_IO3_IO | 0x140332<br>[1:0] | | PB[1] | GPIO | - | PWM3_O/<br>TX_ON_I( | RX_CYC2LNA | CODEC_IRQ_<br>O/<br>HSPI_IO2_IO | 0x140332<br>[3:2] | | PB[2] | GPIO | TX_DATO_I | UARTO_TX/<br>DAC_I_DAT2_I | I2C_SCK_IO | DMIC_DAT_I/<br>HSPI_MISO_IO | 0x140332<br>[5:4] | | PB[3] | GPIO | TX_DAT1_I | UARTO_RTX_IO /DAC_I_DAT3_I | I2C_SDA_IO | DMIC_CLK1/<br>HSPI_MOSI_IO | 0x140332<br>[7:6] | | PB[4] | GPIO | TX_DAT2_I | UARTO_RTS/<br>DAC_I_DAT4_I | PWMO | DMIC_CLK2/<br>HSPI_CK_IO | 0x140333<br>[1:0] | | Pad | Default | Register = 3 | Register = 2 | Register = 1 | Register = 0 | Register | |-------|---------|--------------|------------------------------|--------------|--------------------------|-------------------| | PB[6] | GPIO | RATEO_I | UARTO_CTS_I/<br>DAC_I_DAT6_I | PSPI_MISO_IO | TX_CYC2PA/<br>HSPI_CN_IO | 0x140333<br>[5:4] | | PB[7] | GPIO | RATE1_I | BT_INBAND/<br>DAC_I_DAT7_I | PSPI_MOSI_IO | CODEC_RSTN<br>_I/PWM2 | 0x140333<br>[7:6] | | PC[0] | GPIO | - | PWM0/RX_EN_I | PSPI_CN_IO | SWM_IO | 0x140334<br>[1:0] | | PC[1] | GPIO | - | DMIC_DAT_I/<br>TX_CLK_I | ATSEL[0] | I2C_SCK_IO | 0x140334<br>[3:2] | | PC[2] | GPIO | ADC_I_DATO | DMIC_CLK1/<br>DAC_Q_DAT2_I | ATSEL[1] | I2C_SDA_IO | 0x140334<br>[5:4] | | PC[3] | GPIO | ADC_I_DAT1 | DMIC_CLK2/<br>DAC_Q_DAT3_I | ATSEL[2] | I2S_BCK_IO | 0x140334<br>[7:6] | | PD[0] | GPIO | - | PWMO_N/<br>RX_CLK | PSPI_CN_IO | UARTO_CTS_I | 0x140336<br>[1:0] | | PD[1] | GPIO | - | PWM1_N/<br>ADC_I_DAT3 | PSPI_CK_IO | UARTO_RTS | 0x140336<br>[3:2] | | PD[2] | GPIO | - | PWM2_N/<br>ADC_I_DAT4 | PSPI_MISO_IO | UARTO_TX | 0x140336<br>[5:4] | | PD[3] | GPIO | - | PWM3_N/<br>ADC_I_DAT5 | PSPI_MOSI_IO | UARTO_RTX<br>_IO | 0x140336<br>[7:6] | | PE[0] | GPIO | - | PWM3/<br>FREQ_CHN_I | UART1_TX | I2C_SCK_IO | 0x140350<br>[1:0] | | PE[2] | GPIO | - | PWM2/<br>ADC_Q_DAT4 | UART1_RTX_IO | I2C_SDA_IO | 0x140350<br>[5:4] | | PE[3] | GPIO | BT_ACTIVITY | PWMO/<br>ADC_Q_DAT5 | UART1_RTS | I2C_SDA_IO | 0x140350<br>[7:6] | | PE[4] | TDLI | BT_STATUS | PWM4/<br>ADC_Q_DAT6 | RX_CYC2LNA | TDI_I | 0x140351<br>[1:0] | | PE[5] | TDO | WIFI_DENY_I | PWM5/<br>ADC_Q_DAT7 | TX_CYC2PA | TDO | 0x140351<br>[3:2] | | Pad | Default | Register = 3 | Register = 2 | Register = 1 | Register = 0 | Register | |-------|----------|--------------|---------------|--------------|--------------|-------------------| | PE[6] | TMS_IO | - | ADC_Q_DAT8 | PWM2_N | TMS_IO | 0x140351<br>[5:4] | | PE[7] | TCK_I | - | ADC_Q_DAT9 | PWM3_N | TCK_I | 0x140351<br>[7:6] | | PF[O] | MOSI_IO | - | - | - | MOSI_IO(0) | 0x140356<br>[1:0] | | PF[1] | MSCK | - | - | - | MCLK | 0x140356<br>[3:2] | | PF[2] | MSIO3_IO | - | FAST_STL_I(0) | - | MSIO3_IO | 0x140356<br>[5:4] | | PF[3] | MSCN | - | TX_PWR_I | - | MSCN | 0x140356<br>[7:6] | | PF[4] | MISO_IO | - | - | - | MISO_IO | 0x140357<br>[1:0] | | PF[5] | MSIO2_IO | - | - | - | MSIO2_IO | 0x140357<br>[3:2] | ### Table 10-2 GPIO Setting | Pad | Input | IE | OEN | Output/PE | Polarity | DS | Act as<br>GPIO | |-------|----------|----------|----------|-----------|----------|----------|----------------| | PA[0] | 0x140300 | 0x140301 | 0x140302 | 0x140303 | 0x140304 | 0x140305 | 0x140306 | | | [0] | [0] | [0] | [0] | [0] | [0] | [0] | | PA[1] | 0x140300 | 0x140301 | 0x140302 | 0x140303 | 0x140304 | 0x140305 | 0x140306 | | | [1] | [1] | [1] | [1] | [1] | [1] | [1] | | PA[3] | 0x140300 | 0x140301 | 0x140302 | 0x140303 | 0x140304 | 0x140305 | 0x140306 | | | [3] | [3] | [3] | [3] | [3] | [3] | [3] | | PA[5] | 0x140300 | 0x140301 | 0x140302 | 0x140303 | 0x140304 | 0x140305 | 0x140306 | | | [5] | [5] | [5] | [5] | [5] | [5] | [5] | | PA[6] | 0x140300 | 0x140301 | 0x140302 | 0x140303 | 0x140304 | 0x140305 | 0x140306 | | | [6] | [6] | [6] | [6] | [6] | [6] | [6] | | PA[7] | 0x140300 | 0x140301 | 0x140302 | 0x140303 | 0x140304 | 0x140305 | 0x140306 | | | [7] | [7] | [7] | [7] | [7] | [7] | [7] | | Pad | Input | IE | OEN | Output/PE | Polarity | DS | Act as<br>GPIO | |-------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----------------| | PB[O] | 0x140308<br>[0] | 0x140309<br>[0] | 0x14030a<br>[0] | 0x14030b<br>[0] | 0x14030c<br>[0] | 0x14030d<br>[0] | 0x14030e | | PB[1] | 0x140308<br>[1] | 0x140301<br>[1] | 0x14030a<br>[1] | 0x14030b | 0x14030c<br>[1] | 0x14030d<br>[1] | 0x14030e | | PB[2] | 0x140308<br>[2] | 0x140301<br>[2] | 0x14030a<br>[2] | 0x14030b<br>[2] | 0x14030c<br>[2] | 0x14030d<br>[2] | 0x14030e | | PB[3] | 0x140308<br>[3] | 0x140301<br>[3] | 0x14030a<br>[3] | 0x14030b<br>[3] | 0x14030c<br>[3] | 0x14030d<br>[3] | 0x14030e | | PB[4] | 0x140308<br>[4] | 0x140301<br>[4] | 0x14030a<br>[4] | 0x14030b<br>[4] | 0x14030c<br>[4] | 0x14030d<br>[4] | 0x14030e | | PB[6] | 0x140308<br>[6] | 0x140301<br>[6] | 0x14030a<br>[6] | 0x14030b<br>[6] | 0x14030c<br>[6] | 0x14030d<br>[6] | 0x14030e | | PB[7] | 0x140308<br>[7] | 0x140301<br>[7] | 0x14030a<br>[7] | 0x14030b<br>[7] | 0x14030c<br>[7] | 0x14030d<br>[7] | 0x14030e | | PC[0] | 0x140310<br>[0] | c1[0] | 0x140312<br>[0] | 0x140313<br>[0] | 0x140314<br>[0] | c3[0] | 0x140316 | | PC[1] | 0x140310<br>[1] | c1[1] | 0x140312<br>[1] | 0x140313<br>[1] | 0x140314<br>[1] | c3[1] | 0x140316 | | PC[2] | 0x140310<br>[2] | c1[2] | 0x140312<br>[2] | 0x140313<br>[2] | 0x140314<br>[2] | c3[2] | 0x140316 | | PC[3] | 0x140310<br>[3] | c1[3] | 0x140312<br>[3] | 0x140313<br>[3] | 0x140314<br>[3] | c3[3] | 0x140316 | | PD[0] | 0x140318<br>[0] | c4[0] | 0x14031a<br>[0] | 0x14031b<br>[0] | 0x14031c<br>[0] | c6[0] | 0x140316 | | PD[1] | 0x140318<br>[1] | c4[1] | 0x14031a<br>[1] | 0x14031b<br>[1] | 0x14031c<br>[1] | c6[1] | 0x14031e | | PD[2] | 0x140318<br>[2] | c4[2] | 0x14031a<br>[2] | 0x14031b<br>[2] | 0x14031c<br>[2] | c6[2] | 0x140316 | | PD[3] | 0x140318<br>[3] | c4[3] | 0x14031a<br>[3] | 0x14031b<br>[3] | 0x14031c<br>[3] | c6[3] | 0x140316 | | PE[O] | 0x140320<br>[0] | 0x140321<br>[0] | 0x140322<br>[0] | 0x140323<br>[0] | 0x140324<br>[0] | 0x140325<br>[0] | 0x140326 | | Pad | Input | IE | OEN | Output/PE | Polarity | DS | Act as<br>GPIO | |-------|-----------------|-----------------|-----------------|-----------|-----------------|-----------------|-----------------| | PE[1] | 0x140320 | 0x140321 | 0x140322 | 0x140323 | 0x140324 | 0x140325 | 0x140326 | | | [1] | [1] | [1] | [1] | [1] | [1] | [1] | | PE[2] | 0x140320 | 0x140321 | 0x140322 | 0x140323 | 0x140324 | 0x140325 | 0x140326 | | | [2] | [2] | [2] | [2] | [2] | [2] | [2] | | PE[3] | 0x140320 | 0x140321 | 0x140322 | 0x140323 | 0x140324 | 0x140325 | 0x140326 | | | [3] | [3] | [3] | [3] | [3] | [3] | [3] | | PE[4] | 0x140320 | 0x140321 | 0x140322 | 0x140323 | 0x140324 | 0x140325 | 0x140326 | | | [4] | [4] | [4] | [4] | [4] | [4] | [4] | | PE[5] | 0x140320 | 0x140321 | 0x140322 | 0x140323 | 0x140324 | 0x140325 | 0x140326 | | | [5] | [5] | [5] | [5] | [5] | [5] | [5] | | PE[6] | 0x140320 | 0x140321 | 0x140322 | 0x140323 | 0x140324 | 0x140325 | 0x140326 | | | [6] | [6] | [6] | [6] | [6] | [6] | [6] | | PE[7] | 0x140320 | 0x140321 | 0x140322 | 0x140323 | 0x140324 | 0x140325 | 0x140326 | | | [7] | [7] | [7] | [7] | [7] | [7] | [7] | | PF[0] | 0x140328<br>[0] | 0x140329<br>[0] | 0x14032a<br>[0] | 0x14032b | 0x14032c<br>[0] | 0x14032d<br>[0] | 0x14032e<br>[0] | | PF[1] | 0x140328 | 0x140329<br>[1] | 0x14032a<br>[1] | 0x14032b | 0x14032c<br>[1] | 0x14032d<br>[1] | 0x14032e<br>[1] | | PF[2] | 0x140328 | 0x140329<br>[2] | 0x14032a | 0x14032b | 0x14032c<br>[2] | 0x14032d<br>[2] | 0x14032e<br>[2] | | PF[3] | 0x140328<br>[3] | 0x140329<br>[3] | 0x14032a<br>[3] | 0x14032b | 0x14032c<br>[3] | 0x14032d<br>[3] | 0x14032e<br>[3] | | PF[4] | 0x140328 | 0x140329 | 0x14032a | 0x14032b | 0x14032c | 0x14032d | 0x14032e | | | [4] | [4] | [4] | [4] | [4] | [4] | [4] | | PF[5] | 0x140328 | 0x140329 | 0x14032a | 0x14032b | 0x14032c | 0x14032d | 0x14032e | | | [5] | [5] | [5] | [5] | [5] | [5] | [5] | #### NOTE: - IE: Input enable, high active. 1: enable input, 0: disable input. - OEN: Output enable, low active. O: enable output, 1: disable output. - Output: configure GPO output. - Input: read GPI input. - DS: Drive strength. 1: maximum DS level (default), O: minimal DS level. - Act as GPIO: enable (1) or disable (0) GPIO function. - Polarity: see section below - c1, c3, c4, c6 are analog registers Table 10-3 GPIO Function Mux Configuration Registers | Address | R/W | Description | Default Value | |----------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | 0x140330 | RW | [1:0]: function control bits of PA[0] [3:2]: function control bits of PA[1] [5:4]: function control bits of PA[2] [7:6]: function control bits of PA[3] | 0x00 | | 0x140331 | RW | [1:0]: function control bits of PA[4] [3:2]: function control bits of PA[5] [5:4]: function control bits of PA[6] [7:6]: function control bits of PA[7] | 0x00 | | 0x140332 | RW | [1:0]: function control bits of PB[0] [3:2]: function control bits of PB[1] [5:4]: function control bits of PB[2] [7:6]: function control bits of PB[3] | 0x00 | | 0x140333 | RW | [1:0]: function control bits of PB[4] [3:2]: function control bits of PB[5] [5:4]: function control bits of PB[6] [7:6]: function control bits of PB[7] | 0x00 | | 0x140334 | RW | [1:0]: function control bits of PC[0] [3:2]: function control bits of PC[1] [5:4]: function control bits of PC[2] [7:6]: function control bits of PC[3] | 0x00 | DS-TLSR9515-E5 102 Ver 0.8.4 | Address | R/W | Description | Default Value | | |-----------|--------|---------------------------------------|---------------|--| | | | [1:0]: function control bits of PC[4] | | | | 0x140335 | RW | [3:2]: function control bits of PC[5] | 0,00 | | | OX 140333 | RVV | [5:4]: function control bits of PC[6] | 0x00 | | | | | [7:6]: function control bits of PC[7] | | | | | | [1:0]: function control bits of PD[0] | | | | 0.440226 | DVA | [3:2]: function control bits of PD[1] | 0,400 | | | 0x140336 | RW | [5:4]: function control bits of PD[2] | 0x00 | | | | | [7:6]: function control bits of PD[3] | | | | | | [1:0]: function control bits of PD[4] | | | | 0.440227 | 5).44 | [3:2]: function control bits of PD[5] | | | | 0x140337 | RW | [5:4]: function control bits of PD[6] | 0x00 | | | | | [7:6]: function control bits of PD[7] | | | | | | [1:0]: function control bits of PE[0] | | | | 0140350 | DIA | [3:2]: function control bits of PE[1] | 000 | | | 0x140350 | RW | [5:4]: function control bits of PE[2] | 0x00 | | | | | [7:6]: function control bits of PE[3] | | | | | | [1:0]: function control bits of PE[4] | | | | 0x140351 | RW | [3:2]: function control bits of PE[5] | 0x00 | | | UX14U351 | RVV | [5:4]: function control bits of PE[6] | OXOO | | | | | [7:6]: function control bits of PE[7] | | | | | | [1:0]: function control bits of PE[0] | | | | 0v140356 | DVA | [3:2]: function control bits of PE[1] | 000 | | | 0x140356 | RW | [5:4]: function control bits of PE[2] | 0x00 | | | | | [7:6]: function control bits of PE[3] | | | | 0v140356 | D) 4 / | [1:0]: function control bits of PE[4] | 000 | | | 0x140356 | RW | [3:2]: function control bits of PE[5] | 0x00 | | ## 10.1.2 Connection Relationship between GPIO and Related Modules GPIO can be used to generate GPIO interrupt signal for interrupt system, counting or control signal for Timer/Counter module, or GPIO2RISC interrupt signal for interrupt system. For the "Exclusive Or (XOR)" operation result for input signal from any GPIO pin and respective "Polarity" value, on one hand, it takes "And" operation with "irq" and generates GPIO interrupt request signal; on the other hand, it takes "And" operation with "mO/m1", and generates counting signal in Mode 1 or control signal in Mode 2 for TimerO/Timer1, or generates GPIO2RISC[0]/GPIO2RISC[1] interrupt request signal. DS-TLSR9515-E5 103 Ver 0.8.4 GPIO interrupt request signal = | ((input ^ polarity) & irg); Counting (Mode 1) or control (Mode 2) signal for TimerO = | ((input ^ polarity) & mO); Counting (Mode 1) or control (Mode 2) signal for Timer1 = | ((input ^ polarity) & m1); GPIO2RISC[0] interrupt request signal = | ((input ^ polarity) & m0); GPIO2RISC[1] interrupt request signal = | ((input ^ polarity) & m1). As is shown in figure below. Figure 10-1 Logic Relationship between GPIO and Related Modules ### 10.1.3 Drive Strength The registers in the "DS" column are used to configure the corresponding pin's driving strength: "1" indicates maximum drive level, while "0" indicates minimal drive level. The "DS" configuration will take effect when the pin is used as output. It's set as the strongest driving level by default. In actual applications, driving strength can be decreased to lower level if necessary. ## 10.1.4 Polarity By configuring "Polarity" registers, user can determine GPIO edges in Timer modes. In Timer Mode 1, it determines GPIO edge when Timer Tick counting increases. In Timer Mode 2, it determines GPIO edge when Timer Tick starts counting. Users can read addresses to see which GPIO asserts counting signals (Mode 1)/control signal (Mode 2) for Timers. ## 10.1.5 GPIO IRQ Signal Select GPIO interrupt trigger edge (positive edge or negative edge) via configuring "Polarity", and set corresponding GPIO interrupt enabling bit "Irq". DS-TLSR9515-E5 104 Ver 0.8.4 ## 10.1.6 GPI02RISC IRQ Signal Select GPIO2RISC interrupt trigger edge (positive edge or negative edge) via configuring "Polarity", and set corresponding GPIO enabling bit "m0"/"m1", then enable GPIO2RISC[0]/GPIO2RISC[1] interrupt. Table 10-4 GPIO IRQ Table | Pad | Input | IRQ | m0 | m1 | Polarity | |-------|--------------|-------------|-------------|-------------|--------------| | PA[0] | 0x140300 [0] | 0x140307[0] | 0x140338[0] | 0x140340[0] | 0x140304 [0] | | PA[1] | 0x140300 [1] | 0x140307[1] | 0x140338[1] | 0x140340[1] | 0x140304 [1] | | PA[3] | 0x140300 [3] | 0x140307[3] | 0x140338[3] | 0x140340[3] | 0x140304 [3] | | PA[5] | 0x140300 [5] | 0x140307[5] | 0x140338[5] | 0x140340[5] | 0x140304 [5] | | PA[6] | 0x140300 [6] | 0x140307[6] | 0x140338[6] | 0x140340[6] | 0x140304 [6] | | PA[7] | 0x140300 [7] | 0x140307[7] | 0x140338[7] | 0x140340[7] | 0x140304 [7] | | PB[0] | 0x140308 [0] | 0x14030f[0] | 0x140339[0] | 0x140341[0] | 0x14030c [0] | | PB[1] | 0x140308 [1] | 0x14030f[1] | 0x140339[1] | 0x140341[1] | 0x14030c [1] | | PB[2] | 0x140308 [2] | 0x14030f[2] | 0x140339[2] | 0x140341[2] | 0x14030c [2] | | PB[3] | 0x140308 [3] | 0x14030f[3] | 0x140339[3] | 0x140341[3] | 0x14030c [3] | | PB[4] | 0x140308 [4] | 0x14030f[4] | 0x140339[4] | 0x140341[4] | 0x14030c [4] | | PB[6] | 0x140308 [6] | 0x14030f[6] | 0x140339[6] | 0x140341[6] | 0x14030c [6] | | PB[7] | 0x140308 [7] | 0x14030f[7] | 0x140339[7] | 0x140341[7] | 0x14030c [7] | | PC[0] | 0x140310 [0] | 0x140317[0] | 0x14033a[0] | 0x140342[0] | 0x140314 [0] | | PC[1] | 0x140310 [1] | 0x140317[1] | 0x14033a[1] | 0x140342[1] | 0x140314 [1] | | PC[2] | 0x140310 [2] | 0x140317[2] | 0x14033a[2] | 0x140342[2] | 0x140314 [2] | | PC[3] | 0x140310 [3] | 0x140317[3] | 0x14033a[3] | 0x140342[3] | 0x140314 [3] | | PD[0] | 0x140318 [0] | 0x14031f[0] | 0x14033b[0] | 0x140343[0] | 0x14031c [0] | | PD[1] | 0x140318 [1] | 0x14031f[1] | 0x14033b[1] | 0x140343[1] | 0x14031c [1] | | PD[2] | 0x140318 [2] | 0x14031f[2] | 0x14033b[2] | 0x140343[2] | 0x14031c [2] | | PD[3] | 0x140318 [3] | 0x14031f[3] | 0x14033b[3] | 0x140343[3] | 0x14031c [3] | | PE[O] | 0x140320 [0] | 0x140327[0] | 0x14033c[0] | 0x140344[0] | 0x140324 [0] | | PE[1] | 0x140320 [1] | 0x140327[1] | 0x14033c[1] | 0x140344[1] | 0x140324 [1] | | PE[2] | 0x140320 [2] | 0x140327[2] | 0x14033c[2] | 0x140344[2] | 0x140324 [2] | | PE[3] | 0x140320 [3] | 0x140327[3] | 0x14033c[3] | 0x140344[3] | 0x140324 [3] | | Pad | Input | IRQ | m0 | m1 | Polarity | |-------|--------------|-------------|-------------|-------------|--------------| | PE[4] | 0x140320 [4] | 0x140327[4] | 0x14033c[4] | 0x140344[4] | 0x140324 [4] | | PE[5] | 0x140320 [5] | 0x140327[5] | 0x14033c[5] | 0x140344[5] | 0x140324 [5] | | PE[6] | 0x140320 [6] | 0x140327[6] | 0x14033c[6] | 0x140344[6] | 0x140324 [6] | | PE[7] | 0x140320 [7] | 0x140327[7] | 0x14033c[7] | 0x140344[7] | 0x140324 [7] | | PF[0] | 0x140328 [0] | - | - | - | 0x14032c [0] | | PF[1] | 0x140328 [1] | - | - | - | 0x14032c [1] | | PF[2] | 0x140328 [2] | - | - | - | 0x14032c [2] | | PF[3] | 0x140328 [3] | - | - | - | 0x14032c [3] | | PF[4] | 0x140328 [4] | - | - | - | 0x14032c [4] | | PF[5] | 0x140328 [5] | - | - | - | 0x14032c [5] | ## 10.1.7 Pull-up/Pull-down Resistors All GPIOs support configurable pull-up resistor of rank x1 and x100 or pull-down resistor of rank x10 which are all disabled by default. Analog registers afe\_0x0e<7:0> $\sim$ afe\_0x17<7:0> serve to control the pull-up/pull-down resistor for each GPIO, as shown in table below. Table 10-5 Analog Registers for Pull-up/Pull-down Resistor Control | Address | R/W | Description | Default Value | |---------|-----|-----------------------------------------------------------------------------------------------------|---------------| | 0x0e | R/W | GPIO_A<3:0> pull up and down select: O0: Null O1: 1M pull up 10: 100K pull down 11: 10K pull up | 0000000 | | OxOf | R/W | GPIO_A<7:4> pull up and down select: O0: Null O1: 1M pull up 10: 100K pull down 11: 10K pull up | 0000000 | | Ox10 | R/W | GPIO_B<3:0> pull up and down select: O0: Null O1: 1M pull up 10: 100K pull down 11: 10K pull up | 0000000 | | Address | R/W | Description | Default Valu | |---------|-----|--------------------------------------|--------------| | | | GPIO_B<7:4> pull up and down select: | | | | | 00: Null | | | Ox11 | R/W | O1: 1M pull up | 00000000 | | | | 10: 100K pull down | | | | | 11: 10K pull up | | | | | GPIO_C<3:0> pull up and down select: | | | | | 00: Null | | | 0x12 | R/W | O1: 1M pull up | 00000000 | | | | 10: 100K pull down | | | | | 11: 10K pull up | | | | | GPIO_C<7:4> pull up and down select: | | | | | OO: Null | | | 0x13 | R/W | O1: 1M pull up | 00000000 | | | | 10: 100K pull down | | | | | 11: 10K pull up | | | | | GPIO_D<3:0> pull up and down select: | | | | | 00: Null | | | 0x14 | R/W | O1: 1M pull up | 00000000 | | | | 10: 100K pull down | | | | | 11: 10K pull up | | | | | GPIO_D<7:4> pull up and down select: | | | | | 00: Null | | | 0x15 | R/W | O1: 1M pull up | 00000000 | | | | 10: 100K pull down | | | | | 11: 10K pull up | | | | | GPIO_E<3:0> pull up and down select: | | | | | 00: Null | | | 0x16 | R/W | O1: 1M pull up | 00000000 | | | | 10: 100K pull down | | | | | 11: 10K pull up | | | Address | R/W | Description | Default Value | |---------|-----|-----------------------------------------------------------------------------------------------------|---------------| | Ox17 | R/W | GPIO_E<7:4> pull up and down select: OO: Null O1: 1M pull up 10: 100K pull down 11: 10K pull up | 0000000 | # 10.2 Swire The SoC supports Single Wire Slave interface. SWM (Single Wire Master) and SWS (Single Wire Slave) represent the master and slave device of the single wire communication system developed by Telink. The maximum data rate can be up to 2Mbps. SWS usage is not supported in power-saving mode (deep sleep or suspend). SWS related registers are listed as following, the base address of the following registers is 0x80100c00. Table 10-6 SWIRE Related Registers | Offset | R/W | Description | Default Value | |--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | 0x00 | R | swire_data | 0x00 | | 0x01 | RW | SWIRE_CTL [0]:swire_wr [1]:swire_rd [2]:swire_cmd [3]:swire_err_flag [4]:swire_eop [6]:swire_usb_det [7]:swire_usb_en | 0x80 | | 0x02 | RW | SWIRE_CTL2 [6:0]: swire_clk_div | 0x05 | | 0x03 | RW | [1:0]: function control bits of PB[4] [3:2]: function control bits of PB[5] [5:4]: function control bits of PB[6] [7:6]: function control bits of PB[7] | 0x00 | # 10.3 I2C The SoC embeds I2C hardware module, which could act as Master mode or Slave mode. I2C is a popular inter-IC interface requiring only 2 bus lines, a serial data line (SDA) and a serial clock line (SCL). #### 10.3.1 Communication Protocol Telink I2C module supports standard mode (100kbps) and Fast-mode (400kbps) with restriction that system clock must be by at least 10x of data rate. Two wires, SDA and SCL (SCK) carry information between Master device and Slave device connected to the bus. Each device is recognized by unique address (ID). Master device is the device which initiates a data transfer on the bus and generates the clock signals to permit that transfer. Slave device is the device addressed by a Master. Both SDA and SCL are bidirectional lines connected to a positive supply voltage via a pull-up resister. It's recommended to use external 3.3kohm pull-up resistor. For standard mode, the internal pull-up resistor of rank x1 can be used instead of the external 3.3 kohm pull-up. When the bus is free, both lines are HIGH. It's noted that data in SDA line must keep stable when clock signal in SCL line is at high level, and level state in SDA line is only allowed to change when clock signal in SCL line is at low level. Figure 10-2 I2C Timing #### 10.3.2 I2C Slave Mode I2C module acts as Slave mode by default. I2C slave address can be configured via register I2C\_ID (address 0x01) [7:1], as shown below. DS-TLSR9515-E5 109 Ver 0.8.4 Figure 10-3 Byte Consisted of Slave Address and R/W Flag Bit I2C slave mode supports two sub modes including Direct Memory Access (DMA) mode and No direct Memory Access (NDMA). In I2C Slave mode, Master could initiate transaction anytime. I2C slave module will reply with ACK automatically. To monitor the start of I2C transaction, user could set interrupt from GPIO for SCA or SCL. Read and write format of Slave modes are shown as below. DMA and NDMA access buffer through dma and ahb, respectively. Figure 10-4 Read Format in Slave Mode Figure 10-5 Write Format in Slave Mode #### 10.3.3 I2C Master Mode Register I2CSCTO[1] should be set to 1b'1 to enable I2C master mode. Register I2CSP sets I2C Master clock: $F_{I2C}$ = (System Clock / (4 \*clock speed configured in register I2CSP). A complete I2C protocol contains START, Slave Address, R/W bit, data, ACK and STOP. Slave address could be configured via I2C\_ID [7:1]. I2C Master could send START, Slave Address, R/W bit, data and STOP cycle by configuring SLAVE\_STRECH\_EN. I2C master will send enabled cycles in the correct sequence. Register I2CMST serves to indicate whether Master/Master packet is busy, as well as Master received status. Bit[0] will be set to 1 when one byte is being sent, and the bit can be automatically cleared after a start signal/address byte/acknowledge signal/data /stop signal is sent. Bit[1] is set to 1 when the start signal is sent, and the bit will be automatically cleared after the stop signal is sent. Bit[2] indicates whether to succeed in sending acknowledgement signal. DS-TLSR9515-E5 110 Ver 0.8.4 #### 10.3.3.1 I2C Master Write Transfer in NDMA Mode I2C Master has 8-byte buffer for write data, which are I2C\_data\_buf0, I2C\_data\_buf1, I2C\_data\_buf2 and I 2C\_data\_buf3. Write transfer will be completed by I2C master module. For example, to implement an I2C write transfer with 4-byte data, which contains START, Slave Address, Write bit, ACK from Slave, 1st byte, ACK from slave, 2nd byte, ACK from slave, 3rd byte, ACK from slave,4th byte, ACK from slave and STOP, user needs to configure I2C slave address to I2C\_ID[7:1], 1st byte address to buff. To start I2C write transfer, I2CSCT1 is configured to 0x13 (0001 0011). I2C Master will launch START, Slave address. 1 word data to buff; I2CSCT1 is configured to 0x24 (0000 0024).Write bit, load ACK to I2CMST[2], send buff data, load ACK to I2CMST[2] and then STOP sequentially. 12c supports a single write of 255 bytes. #### 10.3.3.2 I2C Master Read Transfer in NDMA Mode I2C Master has 8 byte buffer for read data, which is fifo (0x08). Read transfer will be completed by I2C Master. For example, to implement an I2C read transfer with 4 byte data, which contains START, Slave Address, Read bit, ACK from Slave, 4 byte from Slave, ACK by master and STOP, user needs to configure I2C slave address to I2C\_ID[7:1]. To start I2C read transfer, I2CSCT1 is configured to 0x7b (0111 1011). I2C Master will launch START, Slave address, Read bit, load ACK to I2CMST[2], load data to I2CDR, reply ACK and then STOP sequentially. I2C supports a single read of 255 bytes. #### 10.3.3.3 I2C Master Writer Transfer in NDMA Mode The data to be sent is put into SRAM, set tx dma config, user needs to configure I2C slave address to I2C\_ID [7:1], 1st byte address to buff. To start I2C write transfer, I2CSCT1 is configured to 0x13 (0001 0011). I2C Master will launch START, Slave address. 1 word data to buff, I2CSCT1 is configured to 0x24 (0000 0024). Write bit, load ACK to I2CMST[2], send buff data, load ACK to I2CMST[2] and then STOP sequentially. I2c supports a single write of 255bytes. #### 10.3.3.4 I2C Master Read Transfer in NDMA Mode For example, set rx dma config, user needs to configure I2C slave address to I2C\_ID[7:1]. To start I2C read transfer, I2CSCT1 is configured to 0x7b (0111 1011). I2C Master will launch START, Slave address, Read bit, load ACK to I2CMST[2], load data to I2CDR, reply ACK and then STOP sequentially. I2c supports a single write of 255 bytes. # 10.3.4 Register Description The I2C related registers are listed as following, the base address of the following registers is 0x80140280. Table 10-7 I2C Related Registers | Address | R/W | Description | Default Value | |---------|-----|------------------------------|---------------| | 0x01 | RW | I2CSP I2C master clock speed | 1f | DS-TLSR9515-E5 111 Ver 0.8.4 | Address R/W | | Description | Default Value | | |-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--| | 0x01 | RW | 12CID<br>12C ID | 5c | | | 0x02 | I2CMST [0]: master busy [1]: master packet busy [2]: master received status: 1 for nak; 0 for ack [5:3]: master state of the base [7:5]: slave state of the base | | 30 | | | OxO3 | I2CSCT [0]: I2C master enable [1]: clk stretch enable, suspend transmission by pulling SCL down to low level, and continue transmission after SCL is released to high level. [2]: rx interrupt enable RW [3]: tx interrupt enable [4]: mask_txdone [5]: mask_rxdone [6]:rnack_en, The last byte data read is automatically returned to nack [7]:Delay sda and oen before ack (ID, ADDRESS, DATAW) | | 00 | | | 0x04 | RW | I2CSCT [0]: launch ID cycle [1]: launch address cycle [2]: launch data write cycle [3]: launch data read cycle [4]: launch start cycle [5]: launch stop cycle [6]: enable read ID [7]: enable ACK in read command | 00 | | | 0x05 | RW | I2CTRIG [3:0]: rx_irq_trig level [7:4]: tx_irq_trig level | 44 | | | Address R/W 0x06 RW | | Description | Default Value | | |----------------------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--| | | | I2CLEN Config buffer send and receive byte number: default 1 byte | 01 | | | 0x07 | RW | SLAVE_STRECH_EN [0]: slave auto stretch clk eanble [1]: slave manul stretch clk [2]: (w) clear slave stretch [6]: standard mode and system clock 48M,maintain ss_scl setup time Max [7]: fast mode:ss_scl setup time small | 00 | | | 0x08 | RW | I2C_data_buf0 write/read buffer[7:0] | - | | | 0x09 | RW | I2C_data_buf1 Write/read buffer[15:8] | - | | | 0x0a | RW | RW Write/read buffer[23:16] | | | | OxOb | RW | I2C_data_buf3 Write/read buffer[31:24] | - | | | ОхОс | R | Buf_cnt [3:0]: rx_buf_cnt [7:4]: tx_buf_cnt | - | | | 0x0d R [3]: i2c | | 12c_sts | - | | | Ox0e | R | <pre>irq_sts [0]: txdone [1]: tx_buf_irq [2]: rxdone [3]: rx_buf_irq [4]: tx_en(W)</pre> | - | | | OxOf | R | rx_fifo_len rx fifo receive byte number | - | | # 10.4 Memory SPI #### NOTE: Memory SPI is available only on TLSR9515D ## 10.4.1 Memory SPI Diagram Memory SPI module is a controller which serves as a SPI master to access SPI flash. Features of memory SPI are listed as following: - APB bus interface for registers configuration - · AHB bus interface for XIP (read-only, 16MB) - · Support for SPI master mode only - LSB byte/MSB bit of data first transfer - Support SPI mode 0 only - Configurable Single, Dual and Quad mode in command, address and data cycle Memory SPI consists of 4 sub-modules, i.e., mspi\_ahbslv, mspi\_apbslv, mspi\_sync and mspi\_ctrl, as shown in figure below: Figure 10-6 Memory SPI Diagram # 10.4.2 Register Description Memory SPI related registers are listed in the following table. Table 10-8 Memory SPI Register Description | Offset R/W | | Description | Default Value | | |------------|--------|-----------------------------------------------------------|---------------|--| | 0x00 | D)A/ | MSPI_DAT_APB | 0,400 | | | OXOO | RW | [7:0]: write data or read data | 0x00 | | | | | MSPI_FM_APB | | | | | | [O]: rdtrig_en_p, read triggle spi enable | | | | 0x01 | RW | [1]: read_mode_p, read mode | 0x00 | | | 0.01 | 1( V V | [3:2]: data_line_p, O:single line; 1: dual line; 2:quad | 0.00 | | | | | line; 3:quad line | | | | | | [4]: csn_p, spi interface csn signal | | | | 0x02 | R | [O]:busy status | 0x2d | | | | | MSPI_FM_APB1 | | | | | | [2:0]: timeout_cnt, csn auto pull high after ahb bus is | | | | 0x03 | RW | idle for timeout_cnt cycle | 0,400 | | | 0.003 | IXVV | [4:3]: cs2sck_cnt, the time of csn low to first sck | 0x00 | | | | | [7:5]: cs2cs_cnt, the time of csn posedge to csn | | | | | | negedge | | | | | | MSPI_SET_L | | | | 0x04 | RW | [2:0]: multi-boot address offset option, 0:0k; 1:128k; | 0x00 | | | | | 2:256k; 4:256k | | | | 0x05 | 200 | MSPI_SET_H | 0x00 | | | UXUS | RW | [6:0]: program space size = mspi_set_h*4k | UXUU | | | | 5,,, | MSPI_CMD_AHB | | | | 0x06 | RW | [7:0]: xip read command | 0x3b | | | | | MSPI_FM_AHB | | | | | | [3:0]: dummy_h, dummy cycle = dummy_h + 1 | | | | 0.07 | RW | [5:4]: dat_line_h, O:single line; 1: dual line; 2:quad | 0.47 | | | 0x07 | | line; 3:quad line | 0x17 | | | | | [6]: addr_line_h, O:single line; 1:the same to dat_line_h | | | | | | [7]: cmd_line_h, O:single line; 1:the same to dat_line_h | | | # 10.5 HSPI # 10.5.1 Diagram HSPI diagram is shown as following: As shown in the diagram, AHB\_BUS is used to configure the direct address mapping of registers and XIP. DMA\_BUS is the bus between the SPI module and the DMA module. SPI\_BUS is the SPI interface connected to the pad. u\_spi\_regif is to parse the AHB protocol and send it to the u\_spi\_reg module for register configuration. The u\_spi\_ctrl module selects the state and mode according to the value of the register configuration, and controls the format of the transmitted data. The u\_spi\_spiif module adjusts the characteristics of the SPI rate or polarity of transmission and reception according to the configuration. The u\_spi\_regif\_ctrl module is mainly used to control and analyze signals related to DMA. The XIP module takes effect when it is configured in XIP mode, and its role is to directly map ahb\_bus to SPI\_BUS. u\_spi\_fifo serves as a buffer for sending and receiving data. Figure 10-7 HSPI Diagram #### 10.5.2 Features The SoC embeds HSPI for high-speed applications, features of HSPI are listed as following: - Supports SPI Master/Slave mode - Supports Dual line, Quad line and 3 line I/O SPI interface - Supports XIP function - Supports LCD driving with SPI ports - · Supports DMA transmission ## 10.5.3 Function Description #### 10.5.3.1 Master Mode Users can define transmit data format by configure TransMode registers, the transmitted data will be written in to HSPI FIFO via software or DMA. Master transfer format is shown as following: Figure 10-8 Master Transfer Mode Format | 8bit cmd(default disable) | 1~4bytes Addr(default<br>disable) | Transfer mode | |---------------------------|-----------------------------------|---------------| |---------------------------|-----------------------------------|---------------| Set the cmd\_en bit of the SPI\_MODE2 register to 1 to indicate that cmd phase is enabled. See SPI\_TRANSO register for transfer mode configuration. The SPI output clock of Master mode can be divided by register, which can be up to ahb\_clock. #### 10.5.3.2 Slave Mode The format that Slave receives is fixed, so the Master needs to send in the prescribed format. Slave transfer format is shown as following: Figure 10-9 Slave Transfer Mode Format | 8bit slave command | 8bit dummy | Slave data | |--------------------|------------|------------| |--------------------|------------|------------| Slave judges the read and write operations of the Master according to the received command. Slave commands are listed in the table below: Table 10-9 Slave Commands | Slave Command | OP Code | Slave Data | |-----------------------|-----------------------|-------------------------------------------------| | Read status single io | 0x05 | 8bit state(slave ready:0x5a or not ready: 0x00) | | Read status dual io | 0x15 | 8bit state(slave ready:0x5a or not ready:0x00) | | Read status quad io | 0x25 | 8bit state(slave ready:0x5a or not ready:0x00) | | Read data single io | 0x0b | Reply data from txfifo | | Read data dual io | ОхОс | Reply data from txfifo | | Read data quad io | 0x0e | Reply data from txfifo | | Write data single io | 0x51 | Data saved to rxfifo | | Write data dual io | 0x52 | Data saved to rxfifo | | Write data quad io | 0x54 | Data saved to rxfifo | | | Any 8bit numbers | | | User-defined | other than the listed | Depending on the transfer control Register | | | OP codes | | DS-TLSR9515-E5 117 Ver 0.8.4 The SPI input clock should be in the following range for Slave mode: master spi\_clk frequency <= 1/4 slave ahb\_clk frequency #### 10.5.3.3 Dual, Quad and 3line I/O Master's Dual and Quad I/O are configured via the following registers: spi\_dual, spi\_quad, cmd\_fmt, Addr\_fmt. Spi\_dual and spi\_quad are used for the Data section. Writing 1 to cmd\_fmt means that the I/O mode of the command is the same as that of the Data section, and writing 1 to Addr\_fmt means that the I/O mode of the Addr is the same as the Data section. Master's 3line I/O mode indicates that mosi is a bidirectional I/O. Configured by spi\_lsb of register SPIMODEO. SPI\_CSN, SPI\_CLK, SPI\_MOSI form a group of SPI interfaces. Slave's Dual and Quad I/O are determined based on the command analyzed by Slave. But Slave's command and dummy are fixed only according to single I/O. Slave also supports 3line mode, and the slave command is only available in single IO mode. The spi\_lsb of the SPIMODEO configuration register is also required. SPI\_CSN, SPI\_CLK, and SPI\_MOSI form a group of SPI interfaces. #### 10.5.3.4 XIP The function of XIP is to map the reading and writing of AHB bus to the timing of SPI. Before the XIP transmission, the SPI mode should be configured, such as dual (quad) I/O, transmode, write/read command, etc. After the SPI modes are all configured, enable the register xip\_enable, at this time the ahb bus request can be converted into SPI timing. #### 10.5.3.5 LCD Display Driving HSPI can drive LCD display with SPI interface. There are 3 ways to drive LCD display with SPI: 3-line, 4-line, 2-line. These 3 methods and all RGB data formats (565, 666, 888) are all supported. The 4-line format requires an additional GPIO to represent the D/CX signal. #### Read/Write Sequences Read/write sequences of 3-line, 4-line and 2-line serial interfaces are shown in figures below. Please be noted, 2-Line serial interface is designed for writing data in LCD screen, so only writing sequence is shown. DS-TLSR9515-E5 118 Ver 0.8.4 Figure 10-10 3-Line Write Sequence Figure 10-11 3-Line Read Sequence Figure 10-12 4-Line Write Sequence Figure 10-13 4-Line Read Sequence Figure 10-14 2-Line Write Sequence #### **RGB Formats** RGB565, RGB666 and RGB888 pixel transitions are shown in figures below. DS-TLSR9515-E5 120 Ver 0.8.4 Figure 10-15 RGB565 Pixel Transition Figure 10-16 RGB666 Pixel Transition Figure 10-17 RGB888 Pixel Transition DS-TLSR9515-E5 121 Ver 0.8.4 ## 10.6 PSPI #### NOTE: PSPI is available only on TLSR9515D ## 10.6.1 Diagram PSPI diagram is shown as following: Figure 10-18 PSPI Diagram As shown in the diagram, the bus between the SPI module and the DMA module. SPI\_BUS is the SPI interface connected to the pad. u\_spi\_regif is to parse the APB protocol and send it to the u\_spi\_reg module for register configuration. The u\_spi\_ctrl module selects the state and mode according to the value of the register configuration, and controls the format of the transmitted data. The u\_spi\_spiif module adjusts the characteristics of the SPI rate or polarity of transmission and reception according to the configuration. The u\_spi\_regif\_ctrl module is mainly used to control and analyze signals related to DMA. u\_spi\_fifo serves as a buffer for sending and receiving data. #### 10.6.2 Features The SoC embeds PSPI for low-power consumption applications, features of PSPI are listed as following: - Supports SPI Master/Slave mode - Supports Dual line and 3 line I/O SPI interface - Supports DMA transmission ### 10.6.3 Function Descriptions #### Master Mode Users can define transmit data format by configure TransMode registers, the transmitted data will be written in to PSPI FIFO via software or DMA. DS-TLSR9515-E5 122 Ver 0.8.4 Master transfer format is shown as following: Figure 10-19 PSPI Master Transfer Format | 8bit cmd(default disable) Transfer mode | |-----------------------------------------| |-----------------------------------------| Write 1 to the cmd\_en bit of the SPI\_MODE2 register to indicate that cmd phase is enabled. See SPI\_TRANSO register for transfer mode configuration. The SPI output clock of Master mode can be divided by register, and the fastest can reach abp\_clock. #### Slave Mode The format that Slave receives is fixed, so the Master needs to send in the prescribed format. Slave transfer format is shown as following: Figure 10-20 Slave Transfer Mode Format | 8bit slave command 8bit dummy Slave data | | |------------------------------------------|--| |------------------------------------------|--| Slave judges the read and write operations of the Master according to the received command. Slave commands are listed in the table below: Table 10-10 Slave Commands | Slave Command | OP Code | Slave Data | |-----------------------|-------------------------------------------------------|-------------------------------------------------| | Read status single io | 0x05 | 8bit state(slave ready:0x5a or not ready: 0x00) | | Read status dual io | 0x15 | 8bit state(slave ready:0x5a or not ready:0x00) | | Read data single io | OxOb | Reply data from txfifo | | Read data dual io | 0x0c | Reply data from txfifo | | Write data single io | 0x51 | Data saved to rxfifo | | Write data dual io | 0x52 | Data saved to rxfifo | | User-defined | Any 8bit numbers<br>other than the listed<br>OP codes | Depending on the transfer control Register | The SPI input clock should be in the following range for Slave mode: master spi\_clk frequency <= 1/4 slave ahb\_clk frequency #### Dual, 3line I/O The Dual I/O of the Master is configured through registers, and the Spi\_dual register is used for the I/O attributes of the Data segment. Command is a fixed single I/O. Master's 3line I/O mode indicates that mosi is a bidirectional I/O. Configured by spi\_Isb of register SPIMODEO. SPI\_CSN, SPI\_CLK, SPI\_MOSI form a group of SPI interfaces. DS-TLSR9515-E5 123 Ver 0.8.4 Slave's Dual I/O is determined based on the command analyzed by Slave. But Slave's command and dummy are fixed only according to single I/O. Slave also supports 3line mode, and the slave command is only available in single io mode. The spi\_lsb of the SPIMODEO configuration register is also required. SPI\_CSN, SPI\_CLK, and SPI\_MOSI form a group of SPI interfaces. # 10.7 SPI Slave (SPI SLV) #### NOTE: SPI Slave is available only on TLSR9515D ### 10.7.1 Diagram SPI\_SLV diagram is shown as below. As shown in the diagram, SPI\_SLAVE\_Interface is used to analyze the protocol of the SPI interface, which is in spi\_clk\_i domain SPI\_SLAVE\_Control is used to synchronize the data of spi\_clk\_i domain to sclk domain, and parse out the address and data segment to AHB\_MASTER module The AHB\_MASTER module synchronizes the data from the sclk domain to the ahb clk domain and sends the parsed address and data to form the AHB bus. SPI SLAVE Interface SPI SLAVE Control CDC sync spi\_clk\_i domain sclk domain ahb clk domain Figure 10-21 SPI\_SLV Diagram #### 10.7.2 Features The SoC embeds SPI\_SLV interface for debugging, features of SPI\_SLV are listed as following: - Supports SPI Slave mode - Supports Dual I/O SPI interface # 10.7.3 Function Description This module converts SPI timing to AHB Master request. SPI Master data should be read and written in formats specified by SPI\_SLV, shown as following: DS-TLSR9515-E5 124 Ver 0.8.4 #### Figure 10-22 SPI\_SLV Write Format | Cmd(8bit) Addr(32bit) | DataO(1byte) | Data1(1byte) | Data | |-----------------------|--------------|--------------|------| |-----------------------|--------------|--------------|------| #### Figure 10-23 SPI\_SLV Read Format | Cmd(8bit) | Addr(32bit) | Dummy(8/4cycle) | DataO(1byte) | Data1(1byte) | Data | |-----------|-------------|-----------------|--------------|--------------|------| | | | | | | | SPI\_SLV determines the format and operation by parsing the commands, shown in the following table. Table 10-11 SPI\_SLV Commands | Name | Description | Default | |----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------| | Cmd[7:0] | Cmd[7]: value 0:spi write, value 1:spi read Cmd[6]: value 0:addr single i/o, value 1:addr dual i/o cmd[5]: value 0:data single i/o, value 1:data dual i/o cmd[4]: value 0:addr auto increase, value 1:disable addr auto increase cmd[3]:value0:read dummy 8 cycle, value1:read dummy 4 cycle cmd[2]: value1:ahb word transfer cmd[1]: value1: ahb half word transfer cmd[0]: reserved | 8'b0000_0000: spi slave write with addr single i/o and data single i/o in the addr auto increasing mode. | Address auto increase does not support ahb word/half word transfer SPI\_CLK\_in supported frequencies: When read\_dummy is 8, SPI\_CLK\_in frequency <= (1/2)\*hclk frequency. When read\_dummy is 4, SPI\_CLK\_in frequency <= (1/4)\*hclk frequency. # 10.8 UART The SoC embeds UART (Universal Asynchronous Receiver/Transmitter) to implement full-duplex transmission and reception via UART TX and RX interface. Both TX and RX interface are 4-layer FIFO (First In First Out) interface. The SoC Supports 2-channel UART, UARTO and UART1. Hardware flow control is supported via RTS and CTS. The UART module also supports ISO7816 protocol to enable communication with ISO/IEC 7816 integrated circuit card, especially smart card. In this mode, half-duplex communication (transmission or reception) is supported via the shared 7816\_TRX interface. DS-TLSR9515-E5 125 Ver 0.8.4 Other Device Telink SoC **UART Module** RTS CTS Write RX buffer TX buffer RX TX MCU or DMA ΤX RX TX buffer Read RX buffer CTS < RTS **UART Module** Figure 10-24 UART Communication As shown in figure above, data to be sent is first written into TX buffer by MCU or DMA, then UART module transmits the data from TX buffer to other device via pin TX. Data to be read from other device is first received via pin RX and sent to RX buffer, then the data is read by MCU or DMA. If RX buffer of the UART is close to full, the SoC will send a signal (configurable high or low level) via pin RTS to inform other device that it should stop sending data. Similarly, if the SoC receives a signal from pin CTS, it indicates that RX buffer of other device is close to full and the SoC should stop sending data. UART related registers are listed in tables below. For UARTO related register, the base address is 0x8140080, for UART1 related register, the base address is 0x81400c0. | Offset | R/W | Description | Default Value | |--------|-----|------------------------------------------------------------------------------|---------------| | 0x00 | R | UART_DATA_BUFO Write/read buffer[7:0] | 0x00 | | OxO1 | R | UART_DATA_BUF1 Write/read buffer[15:8] | 0x00 | | 0x02 | R | UART_DATA_BUF2 Write/read buffer[23:16] | 0x00 | | 0x03 | R | UART_DATA_BUF3 Write/read buffer[31:24] | 0x00 | | 0x04 | RW | UART_CLK_DIV_L uart_cli_div[7:0]:uart clk div register | Oxff | | 0x05 | RW | UART_CLK_DIV_H uart_cli_div[15:8]:uart_sclk = sclk/ (uart_clk_div[14:0]+1) | 0x0f | Table 10-12 UARTO Related Registers | Offset | R/W | Description | Default Value | |--------|-----|-------------------------------------------------------------|---------------| | | | UART_CTRL0 | | | | | [3:0] bpwc, bit width, should be larger than 2 | | | 0x06 | RW | Buadrate = uart_sclk/(bpwc+1) | 0x0f | | | | [6] rx interrupt enable | | | | | [7] tx interrupt enable | | | | | UART_CTRL1 | | | | | [0] cts select, 0: cts_i, 1: cts _i inverter | | | | | [1] cts enable, 1: enable, 0, disable | | | 0x07 | RW | [2] Parity, 1: enable, O:disable | 0x0e | | OXO7 | KVV | [3] even Parity or odd | Oxoe | | | | [5:4] stop bit, 00: 1 bit, 01, 1.5bit 1x: 2bits | | | | | [6] ttl enable | | | | | [7] uart tx, rx loopback | | | | | UART_CTRL2 | | | | | [3:0] rts trig level | | | 0x08 | RW | [4] rts Parity | 0xa5 | | UXUO | KVV | [5] rts manual value | OXAS | | | | [6] rts manual enable | | | | | [7] rts enable | | | | | UART_CTRL3 | | | 0x09 | RW | [3:0] rx_irq_trig level | 0x44 | | | | [7:4] tx_irq_trig level | | | | | UART_RXTIMEOUT_O_L | | | | | r_rxtimeout_o[7:0]:The setting is transfer one bytes | | | 60x0 | RW | need cycles base on uart_clk. For example, if transfer | 0xc0 | | | | one bytes (1start bit+8bits data+1 priority bit+2stop bits) | | | Offset | R/W | Description | Default Value | |--------|----------|---------------------------------------------------------|---------------| | | | UART_RXTIMEOUT_O_H | | | | | [1:0] r_rxtimeout_o[9:8]:R_rxtimeout | | | | | 2'b00:rx timeout time is r_rxtimeout[7:0] | | | | | 2'b01:rx timeout time is r_rxtimeout[7:0]*2 | | | | | 2'b10:rx timeout time is r_rxtimeout[7:0]*3 | | | | | 3'b11: rx timeout time is r_rxtimeout[7:0]*4 | | | 0x0b | RW | R_rxtimeout is for rx dma to decide the end of each | 0x01 | | | | transaction. Supposed the interval between each byte in | | | | | one transaction is very short. | | | | | [2] mask_rxdone | | | | | [5] 7816 enable | | | | | [6] mask_txdone | | | | | [7] mask_err | | | | | UART_BUFCNT | | | 0x0c | Volatile | [3:0] r_buf_cnt | 0x00 | | | | [7:4] t_buf_cnt | | | | | UART_STATUS | | | | | [2:0] rbcnt | | | 0x0d | Volatile | [3] irq | 0x00 | | | | [6:4] R: wbcnt, W: [6] write 1 to clear rx | | | | | [7] R: rx_err, W:[7] write 1 to clear tx | | | | | UART_TXRX_STATUS | | | | | [O] txdone | | | 0x0e | Volatile | [1] txbuf_irq | 0x00 | | | | [2] rxdone | | | | | [3] rxbuf_irq | | | | | UART_STATE | | | 0x0f | Volatile | [2:0] tx state machine | 0x00 | | | | [7:4] rx state machine | | # 10.9 USB The SoC has a full-speed (12Mbps) USB interface for communicating with other compatible digital devices. The USB interface acts as a USB peripheral, responding to requests from a master host controller. The chip contains internal 1.5kohm pull up resistor for the DP pin. Telink USB interface supports the Universal Serial Bus Specification, Revision v2.0 (USB v2.0 Specification). The chip supports 9 endpoints, including control endpoint 0 and 8 configurable data endpoints. Endpoint 1, 2, 3, 4, 7 and 8 can be configured as input endpoint, while endpoint 5 and 6 can be configured as output endpoint. In audio class application, only endpoint 6 supports iso out mode, while endpoint 7 supports iso in mode. In other applications, each endpoint can be configured as bulk, interrupt and iso mode. For control endpoint 0, the chip's hardware vendor command is configurable. #### Optional suspend mode: - Selectable as USB suspend mode or chip suspend mode, support remote wakeup. - Current draw in suspend mode complied with USB v2.0 Specification. - USB pins (DM, DP) can be used as GPIO function in suspend mode. - Resume and detach detect: Recognize USB device by detecting the voltage on the DP pin with configurable 1.5K pull-up resistor. - USB pins configurable as wakeup GPIOs. The USB interface belongs to an independent power domain, and it can be configured to power down independently. The USB related registers are listed in table below, the base address is 0x80100800. Table 10-13 USB Related Registers | Offset | R/W | Description | Default Value | |--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | 0x00 | VOLATILE | EDPOPTR [3:0]: reg_ptr, Endpoint 0 buffer point | 0x00 | | 0x01 | VOLATILE | EDPODAT [7:0]:buff,Endpoint O buffer data access address | 0x00 | | 0x02 | VOLATILE | EDPOCT [0]:ack_data, Ack data [1]:stall_data, Stall data [2]:ack_status, Ack status [3]:stall_status, Stall status | 0x00 | | 0x03 | R | EDPOST [3:0]:udc_cnt,number of data transferred [4]:irq_setup, udc_irq_o={irq_setinf,irq_status,irq_data,irq_setup}: setup interrupt flag [5]:irq_data, data interrupt flag [6]:irq_status, status interrupt flag [7]:irq_setinf, set interface interrupt flag | 0x00 | DS-TLSR9515-E5 129 Ver 0.8.4 | Offset | R/W | Description | Default Value | |--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | | | EDPOMODE [0]:r_en_sadr,enable auto decoding set_address command | | | | | [1]:r_en_cfg ,enable auto decoding set_config command [2]:r_en_inf ,enable auto decoding set_interface command | | | 0x04 | RW | [3]:r_en_sta ,enable auto decoding get_status command [4]:r_en_frm ,enable auto decoding sync_frame command | Oxff | | | | [5]:r_en_desc,enable auto decoding get_descriptor command [6]:r_en_fea,enable auto decoding set_feature | | | | | command [7]:r_en_hw,enable auto decoding standard command | | | 0x05 | RW | USBCT [0]:r_clk_sel_Ouse auto calibrate clock if 1, use system clock if 0 [1]:low_speedlow speed mode if 1; full speed mode if 0 [2]:r_clk_sel_2low jitter mode if 1 | 0x01 | | | | [3]:test_modeusb test mode [7:4]:r_clk_sel_o2 for select 48M RC clock; 1 for 400M RC | | | 0x06 | R | CALCYCL [7:0]:r_clk_div_il,r_clk_div_i | 0x00 | | 0x07 | R | CALCYCH [2:0]:r_clk_div_ih,r_clk_div_i | 0x00 | | 0x0a | RW | MDEV [0]:r_mdev,self power 1: self power 0: bus power [1]:suspend_i,USB suspend status read only [2]:wakeup_feature_o,wakeup feature read only [3]:r_vend,r_vnd[0] vendor cmd offset (byte1[7] == r_vnd[0] means vendor cmd) | 0x00 | | Offset | R/W | Description | Default Value | |--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | 0x0b | RW | EDPOSIE [6:0]:sie_adr_i,sie_adr_i[6:0] [7]:r_config | 0x00 | | ОхОс | RW | SUSPENDCYC, r_suspenf_cnt | 0x18 | | OxOd | R | INFALT [7:0];r_infalt,Interface and alternate setting number in last SET_INTERFACE command | 0x00 | | 0x0e | RW | EDPS_EN [7:0]:edps_en | Oxff | | OxOf | RW | IRQ_MASK [2:0]:r_maskmask[0]: irq_reset; mask[1]:irq_250us; mask[2]:irq_suspend; [4:3]:r_lvllvl[0]:0>irq_reset_edge;1>usb_reset_i; lvl[1]:0>irq_250us_edge; 1>usb_250us_i; [5]:irq_reset_oW:Clear usb reset edge interrupted [6]:irq_250us_oW:Clear usb 250us edge interrupted [7]:irq_suspend_oUSB suspend status read only: mask & suspend | 0x04 | | 0x10 | VOLATILE | EDPSPTR [7:0]:rd_ptrl | 0x00 | | 0x11 | VOLATILE | EDPS1PTR [7:0]:rd_ptrl | 0x00 | | 0x12 | VOLATILE | EDPS2PTR [7:0]:rd_ptrl | 0x00 | | 0x13 | VOLATILE | EDPS3PTR [7:0]:rd_ptrl | 0x00 | | 0x14 | VOLATILE | EDPS4PTR [7:0]:rd_ptrl | 0x00 | | 0x15 | VOLATILE | EDPS5PTR [7:0]:rd_ptrl | 0x00 | | 0x16 | VOLATILE | EDPS6PTR [7:0]:rd_ptrl | 0x00 | | Offset | R/W | Description | Default Value | |--------|----------|------------------------------------------------------------------------------------------------------------------------------------------|---------------| | 0x17 | VOLATILE | EDPS7PTR [7:0]:rd_ptrl | 0x00 | | 0x18 | VOLATILE | EDPSDATA [7:0]:sr_q | 0x00 | | 0x19 | VOLATILE | EDPS1DATA [7:0]:sr_q | 0x00 | | 0x1a | VOLATILE | EDPS2DATA [7:0]:sr_q | 0x00 | | Ox1b | VOLATILE | EDPS3DATA [7:0]:sr_q | 0x00 | | 0x1c | VOLATILE | EDPS4DATA [7:0]:sr_q | 0x00 | | Ox1d | VOLATILE | EDPS5DATA [7:0]:sr_q | 0x00 | | 0x1e | VOLATILE | EDPS6DATA [7:0]:sr_q | 0x00 | | 0x1f | VOLATILE | EDPS7DATA [7:0]:sr_q | 0x00 | | 0x20 | VOLATILE | EDPSCT [0]:rd_ack [1]:rd_stall [2]:set_data0,Set Data0 [3]:set_data1,Set Data1 [7]:edp8_dma_eofLaunch EOF for FIFO mode (W) (no support) | 0x00 | | Ox21 | VOLATILE | EDP1SCT [0]:rd_ack [1]:rd_stall [2]:set_data0,Set Data0 [3]:set_data1,Set Data1 | 0x00 | | Offset | R/W | Description | Default Value | |--------|----------|-------------------------------------|---------------| | | | EDP2SCT | | | | | [O]:rd_ack | | | 0x22 | VOLATILE | [1]:rd_stall | 0x00 | | | | [2]:set_data0?Set Data0 | | | | | [3]:set_data1?Set Data1 | | | | | EDP3SCT | | | | | [O]:rd_ack | | | 0x23 | VOLATILE | [1]:rd_stall | 0x00 | | | | [2]:set_dataO,Set DataO | | | | | [3]:set_data1,Set Data1 | | | | | EDP4SCT | | | | | [0]:rd_ack | | | 0x24 | VOLATILE | [1]:rd_stall | 0x00 | | | | [2]:set_data0,Set Data0 | | | | | [3]:set_data1,Set Data1 | | | | | EDP5SCT | | | | | [0]:rd_ack | | | 0x25 | VOLATILE | [1]:rd_stall | 0x00 | | | | [2]:set_data0,Set Data0 | | | | | [3]:set_data1,Set Data1 | | | | | EDP6SCT | | | | | [0]:rd_ack,ACK | | | | | [1]:rd_stall,Stall | | | 0x26 | VOLATILE | [2]:set_data0,Set Data0 | - | | | | [3]:set_data1,Set Data1 | | | | | [6]:rd_mono_aout,MONO mode | | | | | [7]:rd_en_aout,Audio ISO out enable | | | | | EDP7SCT | | | | | [O]:rd_ack,ACK | | | | | [1]:rd_stall,Stall | | | 0x27 | VOLATILE | [2]:set_dataO,Set DataO | - | | | | [3]:set_data1,Set Data1 | | | | | [6]:rd_mono_aout,MONO mode | | | | | [7]:rd_en_aout,Audio ISO out enable | | | Offset | R/W | Description | Default Value | |--------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | 0x28 | VOLATILE | EDPSADR,rd_adr | 0x80 | | 0x29 | RW | EDPS1ADR,Endpoint 1 buffer address | 0x00 | | 0x2a | RW | EDPS2ADR,Endpoint 2 buffer address | 0x08 | | 0x2b | RW | EDPS3ADR,Endpoint 3 buffer address | 0x10 | | 0x2c | RW | EDPS4ADR,Endpoint 4 buffer address | 0x40 | | 0x2d | RW | EDPS5ADR,Endpoint 5 buffer address | 0xc0 | | 0x2e | RW | EDPS6ADR,Endpoint 6 buffer address | 0x20 | | 0x2f | RW | EDPS7ADR,Endpoint 7 buffer address | 0x30 | | 0x30 | RW | USBRAM [O]:sr_cen,CEN in power down mode [1]:sr_clk,CLK in power down mode [2]:r_ram2,Reserved [3]:wen_i,WEN in power down mode [4]:r_ram4,CEN in function mode | 0x18 | | 0x38 | RW | USBSOEnable endpoint ISO mode | 0xc0 | | 0x39 | RW | USBIRQ [7:0]:r_irq,Endpoint data transfer interrupt | 0x00 | | 0x3a | RW | USBMASK,Endpoint interrupt mask | Oxff | | 0x3b | RW | USBMAXO, Maximum endpoint 8 transfer number | 0x10 | | 0x3c | RW | USBMINO, Minimum threshold to ACK endpoint 8 transfer | 0x40 | | 0x3d | RW | USBFIFO [0]:r_fifo0,Endpoint 0 FIFO mode [1]:full0,Full flag [2]:r_mode00 [3]:edp8_eof [6:4]:edp8_dma_eof [7]:r_mode05 | - | | 0x3e | RW | USBMAX [6:0]:məx_in, USBMAX*8 | 0x08 | | 0x3f | VOLATILE | USBTICK | 0x00 | # **11 PWM** The SoC supports 6-channel PWM (Pulse-Width-Modulation) output. Each PWM#n (n=0~5) has its corresponding inverted output at PWM#n\_N pin. ### 11.1 Enable PWM Register PWM\_EN[5:1] and PWM\_EN0[0] serves to enable PWM5-PWM0 respectively via writing "1" for the corresponding bits. # 11.2 Set PWM Clock PWM clock derives from system clock. Register PWM\_CLKDIV serves to set the frequency dividing factor for PWM clock. Formula below applies: $$F_{PWM} = F_{System \ clock} / (PWM_CLKDIV+1)$$ # 11.3 PWM Waveform, Polarity and Output Inversion Each PWM channel has independent counter and 2 status including "Count" and "Remaining". Count and Remaining status form a signal frame. ## 11.3.1 Waveform of Signal Frame When PWM#n is enabled, first PWM#n enters Count status and outputs High level signal by default. When PWM#n counter reaches cycles set in register PWM\_TCMP#n / PWM\_TCMP\_FSK\_L/PWM\_TCMP\_FSK\_H PWM#n enters Remaining status and outputs Low level till PWM#n cycle time configured in register PWM\_TMAX#n / PWM\_TMAX\_FSK\_L/ PWM\_TMAX\_FSK\_H expires. An interruption will be generated at the end of each signal frame if enabled via register PWM\_MASK. Signal frame is shown as following: Count status CMP Remaining status DS-TLSR9515-E5 135 Ver 0.8.4 ### 11.3.2 Invert PWM Output PWM#n and PWM#n\_N output could be inverted independently via register PWM\_CCO and PWM\_CC1. When the inversion bit is enabled, waveform of the corresponding PWM channel will be inverted completely. ### 11.3.3 Polarity for Signal Frame By default, PWM#n outputs High level at Count status and Low level at Remaining status. When the corresponding polarity bit is enabled via register PWM\_CC2[5:0], PWM#n will output Low level at Count status and High level at Remaining status. PWM output waveform is shown as below. Figure 11-2 PWM Output Waveform Chart # 11.4 PWM Mode #### 11.4.1 Select PWM Modes PWMO supports five modes, including Continuous mode (normal mode, default), Counting mode, IR mode, IR FIFO mode, IR DMA FIFO mode. PWM1~PWM5 only support Continuous mode. Register PWM\_MODE serves to select PWMO mode. #### 11.4.2 Continuous Mode PWM0~PWM5 all support Continuous mode. In this mode, PWM#n continuously sends out signal frames. PWM#n should be disabled via PWM\_EN/PWN\_ENO to stop it; when stopped, the PWM output will turn low immediately. During Continuous mode, waveform could be changed freely via PWM\_TCMP#n and PWM\_TMAX#n. New configuration for PWM\_TCMP#n and PWM\_TMAX#n will take effect in the next signal frame. DS-TLSR9515-E5 136 Ver 0.8.4 After each signal frame is finished, corresponding PWM cycle done interrupt flag bit (PWM\_INT[2:7]) will be automatically set to 1b'1. If the interrupt is enabled by setting PWM\_MASKO[2:7] as 1b'1, a frame interruption will be generated. User needs to write 1b'1 to the flag bit to manually clear it. Figure 11-3 Continuous Mode ## 11.4.3 Counting Mode Only PWMO supports Counting mode. PWM\_MODE [2:0] should be set as 4b'0001 to select PWMO counting mode. In this mode, PWMO sends out specified number of signal frames which is defined as a pulse group. The number is configured via register PWM\_PNUM. After each signal frame is finished, PWMO cycle done interrupt flag bit (PWM\_INT[2]) will be automatically set to 1b'1. If the interrupt is enabled by setting PWM\_MASKO [2] as 1b'1, a frame interruption will be generated. User needs to write 1b'1 to the flag bit to manually clear it. After a pulse group is finished, PWMO will be disabled automatically, and PWMO pnum interrupt flag bit (PWM\_INT [0]) will be automatically set to 1b'1. If the interrupt is enabled by setting PWM\_MASKO as 1b'1, a Pnum interruption will be generated. User needs to write 1b'1 to the flag bit to manually clear it. Counting mode also serves to stop IR mode gracefully. #### 11.4.4 IR Mode Only PWMO supports IR mode. PWM\_MODE[2:0] should be set as 4b'0011 to select PWMO IR mode. In this mode, specified number of frames is defined as one pulse group. In contrast to Counting mode where PWMO stops after first pulse group is finished, PWMO will constantly send pulse groups in IR mode. DS-TLSR9515-E5 137 Ver 0.8.4 During IR mode, PWMO output waveform could also be changed freely via PWM\_TCMPO, PWM\_TMAXO and PWM\_PNUMO. New configuration for PWM\_TCMPO, PWM\_TMAXO and PWM\_PNUMO will take effect in the next pulse group. To stop IR mode and complete current pulse group, user can switch PWMO from IR mode to Counting mode so that PWMO will stop after current pulse group is finished. If PWMO is disabled directly via PWM\_ENO[0], PWMO output will turn Low immediately despite of current pulse group. After each signal frame/pulse group is finished, PWMO cycle done interrupt flag bit (PWM\_INT[2])/PWMO pnum interrupt flag bit (PWM\_INT[0]) will be automatically set to 1b'1. A frame interruption/Pnum interruption will be generated. Figure 11-5 IR Mode (n=0) ### 11.4.5 IR FIFO Mode IR FIFO mode is designed to allow IR transmission of long code patterns without the continued intervention of MCU, and it is designed as a selectable working mode on PWMO. The IR carrier frequency is divided down from the system clock and can be configured as any normal IR frequencies, e.g. 36kHz, 38kHz, 40kHz, or 56kHz. Only PWMO supports IR FIFO mode. PWM\_MODE[2:0] should be set as 4b'0111 to select PWMO IR FIFO mode. An element ("FIFO CFG Data") is defined as basic unit of IR waveform, and written into FIFO. This element consists of 16 bits, including: - bit[13:0] defines PWM pulse number of current group. - bit[14] determines duty cycle and period for current PWM pulse group. - 0: use configuration of TCMPO and TMAXO; - 1: use configuration of PWM\_TCMP\_FSK\_L/PWM\_TCMP\_FSK\_H and PWM\_TMAX\_FSK\_L/PWM\_TMAX\_FSK\_H. - bit[15] determines whether current PWM pulse group is used as carrier, i.e. whether PWM will output pulse (1) or low level (0). User should use PWM\_RDAT\_LO, PWM\_RDAT\_HO, PWM\_RDAT\_L1, PWM\_RDAT\_H1 in 0x7c8-0x7cb to write the 16-bit "FIFO CFG Data" into FIFO by byte or half word or word. - To write by byte, user should successively write 0x7c8, 0x7c9, 0x7ca and 0x7cb. - To write by half word, user should successively write 0x7c8 and 0x7ca. - To write by word, user should write 0x7c8. DS-TLSR9515-E5 138 Ver 0.8.4 FIFO depth is 8 bytes. User can read the register FIFO\_SR in 0x7cd to view FIFO empty/full status and check FIFO data number. When "FIFO CFG Data" is configured in FIFO and PWMO is enabled via PWM\_ENO[0], the configured waveforms will be output from PWMO in sequence. As long as FIFO doesn't overflow, user can continue to add waveforms during IR waveforms sending process, and long IR code that exceeds the FIFO depth can be implemented this way. After all waveforms are sent, FIFO becomes empty, PWMO will be disabled automatically. The FIFO\_CLR register serves to clear data in FIFO. Writing 1b'1 to this register will clear all data in the FIFO. Note that the FIFO can only be cleared when not in active transmission. #### 11.4.6 IR DMA FIFO Mode IR DMA FIFO mode is designed to allow IR transmission of long code patterns without occupation of MCU, and it is designed as a selectable working mode on PWMO. The IR carrier frequency is divided down from the system clock and can be configured as any normal IR frequencies, e.g. 36 kHz, 38 kHz, 40 kHz, or 56 kHz. Only PWM0 supports IR DMA FIFO mode.PWM\_MODE[3:0] should be set as 4b'1111 to select PWM0 IR DMA FIFO mode. DS-TLSR9515-E5 139 Ver 0.8.4 This mode is similar to IR FIFO mode, except that "FIFO CFG Data" is written into FIFO by DMA instead of MCU. User should write the configuration of "FIFO CFG Data" into RAM, and then enable DMA channel 5. DMA will automatically write the configuration into FIFO. **NOTE:** In this mode, when DMA channel 5 is enabled, PWM will automatically output configured waveform, without the need to manually enable PWMO via PWM\_ENO (i.e. PWM\_ENO[O] will be set as 1b'1 automatically). # 11.5 PWM Interrupt There are 9 interrupt sources from PWM function. After each signal frame, PWM#n ( $n = 0 \sim 5$ ) will generate a frame-done IRQ (Interrupt Request) signal. In Counting mode and IR mode, PWMO will generate a Pnum IRQ signal after completing a pulse group. In IR FIFO mode, PWMO will generate a FIFO mode count IRQ signal when the FIFO\_NUM value is less than the FIFO\_NUM\_LVL, and will generate a FIFO mode stop IRQ signal after FIFO becomes empty. In IR DMA FIFO mode, PWMO will generate an IR waveform send done IRQ signal, after DMA has sent all configuration data, FIFO becomes empty and final waveform is sent. To enable PWM interrupt, the total enabling bit "irq\_pwm" should be set as 1b'1. To enable various PWM interrupt sources, PWM\_MASKO and PWM\_MASK1 should be set as 1b'1 correspondingly. Interrupt status can be cleared via register PWM\_INTO and PWM\_INT1. # 11.6 Register Description PWM related registers are listed as following. The base address for below registers is 0x80140400. Table 11-1 PWM Registers | Offset | R/W | Description | Default Value | |--------|-----|------------------------------------------------------|---------------| | 0x00 | W | PWM_EN pwm[5:1] enable | 0x00 | | 0x01 | W | PWM_ENO pwm0 enable | 0x00 | | 0x02 | RW | PWM_CLKDIV | 0x00 | | 0x03 | RW | PWM_MODE [0]:crun_o [1]:catch_o [2]:fifio_mode_en | 0x00 | | 0x04 | RW | PWM_CCO invert PWM output | 0x00 | DS-TLSR9515-E5 140 Ver 0.8.4 | Offset | R/W | Description | Default Valu | |--------|-----|-----------------------------------------------------------------------|--------------| | 0x05 | RW | PWM_CC1 invert PWM_INV output | 0x00 | | 0x06 | RW | PWM_CC2 PWM pola | 0x00 | | 0x07 | RW | MODE32K | 0x00 | | Ox14 | RW | PWM_TCMP0_L tcmpb0[7:0] bits 7-0 of PWM0's high time or low time | 0x00 | | Ox15 | RW | PWM_TCMP0_H tcmpb0[15:8] bits 15-8 of PWM0's high time or low time | 0x00 | | 0x16 | RW | PWM_TMAXO_L tmaxb0[7:0] bits 7-0 of PWM0's cycle time | 0x00 | | 0x17 | RW | PWM_TMAXO_H tmaxb0[15:8] bits 15-8 of PWM0's cycle time | 0x00 | | Ox18 | RW | PWM_TCMP1_L tcmpb1_o[7:0] bits 7-0 of PWM1's high time or low time | 0x00 | | 0x19 | RW | PWM_TCMP1_H tcmpb1_o[15:8] bits 15-8 of PWM1's high time or low time | 0x00 | | Ox1a | RW | PWM_TMAX1_L tmaxb1_o[7:0] bits 7-0 of PWM1's cycle time | 0x00 | | Ox1b | RW | PWM_TMAX1_H<br>tmaxb1_o[15:8] bits 15-8 of PWM1's cycle time | 0x00 | | Ox1c | RW | PWM_TCMP2_L tcmpb2_o[7:0] bits 7-0 of PWM2's high time or low time | 0x00 | | Ox1d | RW | PWM_TCMP2_H tcmpb2_o[15:8] bits 15-8 of PWM2's high time or low time | 0x00 | | Offset | R/W | Description | Default Value | |--------|-----|----------------------------------------------------------------------|---------------| | Ox1e | RW | PWM_TMAX2_L tmaxb2_o[7:0] bits 7-0 of PWM2's cycle time | 0x00 | | Ox1f | RW | PWM_TMAX2_H tmaxb2_o[15:8] bits 15-8 of PWM2's cycle time | 0x00 | | 0x20 | RW | PWM_TCMP3_L tcmpb3_o[7:0] bits 7-0 of PWM3's high time or low time | 0x00 | | 0x21 | RW | PWM_TCMP3_H tcmpb3_o[15:8] bits 15-8 of PWM3's high time or low time | 0x00 | | 0x22 | RW | PWM_TMAX3_L tmaxb3_o[7:0] bits 7-0 of PWM3's cycle time | 0x00 | | 0x23 | RW | PWM_TMAX3_H tmaxb3_o[15:8] bits 15-8 of PWM3's cycle time | 0x00 | | 0x24 | RW | PWM_TCMP4_L tcmpb4_o[7:0] bits 7-0 of PWM4's high time or low time | 0x00 | | 0x25 | RW | PWM_TCMP4_H tcmpb4_o[15:8] bits 15-8 of PWM4's high time or low time | 0x00 | | 0x26 | RW | PWM_TMAX4_L tmaxb4_o[7:0] bits 7-0 of PWM4's cycle time | 0x00 | | 0x27 | RW | PWM_TMAXB4_H tmaxb4_o[15:8] bits 15-8 of PWM4's cycle time | 0x00 | | 0x28 | RW | PWM_TCMP5_L tcmpb5_o[7:0] bits 7-0 of PWM5's high time or low time | 0x00 | | 0x29 | RW | PWM_TCMP5_H tcmpb5_o[15:8] bits 15-8 of PWM5's high time or low time | 0x00 | | 0x2a | RW | PWM_TMAX5_L tmaxb5_o[7:0] bits 7-0 of PWM5's cycle time | 0x00 | | Offset | R/W | Description | Default Value | |--------|----------|-------------------------------------------------------------------------------------------------------------------------|---------------| | 0x2b | RW | PWM_TMAX5_H<br>tmaxb5_o[15:8] bits 15-8 of PWM5's cycle time | 0x00 | | 0x2c | RW | PWM_PNUM_L pnumb[7:0] | 0x00 | | 0x2d | RW | PWM_PNUM_H pnumb[13:8] | 0x00 | | 0x30 | RW | PWM_MASK [0]:mask_pwm [1]:mask_fifo [7:2]:mask | 0x00 | | 0x31 | VOLATILE | PWM_INT [0]:int_pwm,count model interrupt flag [1]:int_fifo_done,int_fifo_done [7:2]:int_flag,w1c too, int_flag[5:0] | 0x00 | | 0x32 | RW | PWM_MASK_LVL | 0x00 | | 0x33 | VOLATILE | PWM_INT_LVL | 0x00 | | 0x34 | VOLATILE | PWM_CNTO_L | 0x00 | | 0x35 | VOLATILE | PWM_CNTO_H | 0x00 | | 0x36 | VOLATILE | PWM_CNT1_L | 0x00 | | 0x37 | VOLATILE | PWM_CNT1_H | 0x00 | | 0x38 | VOLATILE | PWM_CNT2_L | 0x00 | | 0x39 | VOLATILE | PWM_CNT2_H | 0x00 | | 0x3a | VOLATILE | PWM_CNT3_L | 0x00 | | 0x3b | VOLATILE | PWM_CNT3_H | 0x00 | | 0x3c | VOLATILE | PWM_CNT4_L | 0x00 | | 0x3d | VOLATILE | PWM_CNT4_H | 0x00 | | 0x3e | VOLATILE | PWM_CNT5_L | 0x00 | | 0x3f | VOLATILE | PWM_CNT5_H | 0x00 | | 0x40 | R | PWM_NCNT_L | 0x00 | | 0x41 | R | PWM_NCNT_H | 0x00 | | Offset | R/W | Description | Default Value | |--------|----------|----------------|---------------| | 0x44 | RW | PWM_TCMP_FSK_L | 0x00 | | 0x45 | RW | PWM_TCMP_FSK_H | 0x00 | | 0x46 | RW | PWM_TMAX_FSK_L | 0x00 | | 0x47 | RW | PWM_TMAX_FSK_H | 0x00 | | 0x48 | R | PWM_RDAT_LO | 0x00 | | 0x49 | R | PWM_RDAT_H0 | 0x00 | | 0x4a | R | PWM_RDAT_L1 | 0x00 | | 0x4b | R | PWM_RDAT_H1 | 0x00 | | 0x4c | RW | PWM_FIFO_LVL | 0x00 | | 0x4d | VOLATILE | PWM_TX_CTRL | 0x10 | | 0x4e | W | CLR_TXFIFO | 0x00 | # 12 Manchester Decoder(MDEC) The SoC integrates one Manchester Decoder (MDEC). The MDEC is designed to decode the input Manchester code, data after Manchester coding, into binary data. #### NOTE: MDEC is available only on TLSR9515D #### 12.1 Frame Format The MDEC's input sequence includes a Carrier signal, a Start flag, a 39-bit mdec\_data filed (mdec\_data[38:0]), and an End flag. - · Carrier signal duration should be no less than 3ms. - Support duty cycle of 50%~90%. - · Period for each bit is 408us. - The Start flag is Manchester code 1, a positive edge from low level to high level. - The End flag is Manchester code O, a negative edge from high level to low level. The frame format is shown as following: Figure 12-1 Frame Format ## 12.2 Function Description #### 12.2.1 Block Diagram Function block diagram is shown below: Figure 12-2 MDEC Function Block Diagram As shown in figure above, the MDEC uses 32kHz clock, and it mainly embeds a finite State machine, three counters, and a Shift Register to implement its function, including: - Finite State Machine: It includes Idle state, Carrier state, Start state, Data state, and End state. - count\_carrier: This counter serves to detect carrier signal in Idle state. When a carrier signal is detected, the MDEC's state machine enters Start state. - count\_32k: After entering Start state, this counter serves to calculate the interval between two adjacent positive edges, so as to judge the input data. - count\_bit: This counter serves to record the number of bits that have been decoded, so as to judge whether data decoding - of a frame is finished. When the bit number reaches 39, it indicates decoding is finished. - Shift Register: This register serves to store binary data after decoding. #### 12.2.2 Reset MDEC The analog register afe\_0x53 bit[7] serves to reset the MDEC module. To use the MDEC, it's needed to set this bit as 1b'0. #### 12.2.3 Select Input Channel User can input the Manchester code from specific GPIO pin into the MDEC. The analog register afe\_0x53 bits[4:0] serves to select PA[0], PB[7], PC[4], PD[0] and PE[0] as input channel, respectively. #### 12.2.4 Read Result Data Data after decoding, mdec\_data[38:0], are available in the Shift Register, i.e. the analog registers afe\_0x6a~afe\_0x6e. After data decoding of a frame is finished, if the 4-bit mdec\_data[38:35] in the analog register afe\_0x69[7:4]) is consistent with the mdec\_match\_value written in the analog register afe\_0x54[3:0], a MCU wakeup signal will be generated. ## 12.3 Register Description MDEC related register are listed in table below. DS-TLSR9515-E5 146 Ver 0.8.4 #### Table 12-1 MDEC Related Registers | Address | R/W | Description | Default Value | |----------|--------|-----------------------------------------------------|---------------| | | | [4:0] mdec_sel | | | | | [0]:PA[0] as mdec input | | | | | [1]:PB[7] as mdec input | | | afe_0x53 | R/W | [2]:PC[4] as mdec input | _ | | 010_0833 | 1,7,11 | [3]:PD[0] as mdec input | | | | | [4:]:PE[0] as mdec input | | | | | [7]: Mdec_rst,reset mdec module :1, reset enable,0: | | | | | reset disable | | | ofo 0 | D ()A/ | MDEC ctrl bit | 00010 | | afe_0x54 | R/W | [3:0]: Manchester decoder control bit field value | 0x0010 | | | | mdec_rcv_data[38:32] | | | afe_0x6a | | [2:0] mdec_rcv_data[34:32] | | | ale_0x6a | R | [3] rsvd | _ | | | | [7:4] mdec_rcv_data[38:35] | | | afa Ouch | D | mdec_rcv_data[31:24] | | | afe_0x6b | R | [7:0] mdec_rcv_data[31:24] | _ | | -1-0.6- | | mdec_rcv_data[23:16] | | | afe_0x6c | R | [7:0] mdec_rcv_data[23:16] | - | | -f- 0 64 | 5 | mdec_rcv_data[15:8] | | | afe_0x6d | R | [7:0] mdec_rcv_data[15:8] | - | | -f- 0C- | D | mdec_rcv_data[7:0] | | | afe_0x6e | R | [7:0] mdec_rcv_data[7:0] | - | ### 13 SAR ADC The SoC integrates one SAR ADC module, which can be used to sample analog input signals such as battery voltage and temperature sensor. The diagram of SAR ADC module is shown in figure below. afe 0xec<6> afe\_0xf3<0> Not\_sample\_ Differential adc\_en\_diff mode adcdat 1 Set as 0 to read adc dat afe 0xeb<7:4> 0x5 positive input PB[4] ADC adc\_ain\_p adc dat [15:0] 0x6 negative input PB[5] adc\_ain\_n afe 0xeb<3:0> {afe 0xf8, afe 0xf7} Figure 13-1 Diagram of ADC ## 13.1 Power On/Down The SAR ADC is disabled by default. To power on the ADC, the analog register adc\_pd (afe\_0xfc<5>) should be set as 1b'0. #### 13.2 ADC Clock ADC clock is derived from external 24 MHz crystal source, with frequency dividing factor configurable via the analog register adc\_clk\_div (afe\_0xf4<2:0>). ADC clock frequency (marked as $F_{ADC clk}$ ) = 24MHz/(adc\_clk\_div+1) ### 13.3 ADC Control in Auto Mode #### 13.3.1 Set Max State and Enable Channel The SAR ADC supports Misc channel which consists of one "Set" state and one "Capture" state. - The analog register r\_max\_scnt (afe\_0xf2<5:4>) serves to set the max state index. As shown below, the r\_max\_scnt should be set as 0x02. - The Misc channel can be enabled via r\_en\_misc (afe\_0xf2<2>). DS-TLSR9515-E5 148 Ver 0.8.4 #### 13.3.2 "Set" State The length of "Set" state for the Misc channel is configurable via the analog register r\_max\_s (afe\_0xf1<3:0>). "Set" state duration (marked as $T_{sd}$ ) = r\_max\_s / 24MHz. Each "Set" state serves to set ADC control signals for the Misc channel via corresponding analog registers, including: - adc\_en\_diff: afe\_0xec<6>. MUST set as 1b'1 to select differential input mode. - adc\_ain\_p: afe\_0xeb<7:4>. Select positive input in differential mode. - adc\_ain\_n: afe\_0xeb<3:0>. Select negative input in differential mode. - adc\_vref: afe\_Oxe - a<1:0>. Set reference voltage V<sub>REF</sub>. ADC maximum input range is determined by the ADC reference voltage. - adc\_sel\_ai\_scale: afe\_0xfa<7:6>. Set scaling factor for ADC analog input as 1 (default), or 1/8. By setting this scaling factor, ADC maximum input range can be extended based on the V<sub>REF</sub>. For example, suppose the $V_{RFF}$ is set as 1.2V: Since the scaling factor is 1 by default, the ADC maximum input range should be 0-1.2V (negative input is GND) / -1.2V-+1.2V (negative input is ADC GPIO pin). If the scaling factor is set as 1/8, in theory ADC maximum input range should change to 0~9.6V (negative input is GND) / -9.6V~+9.6V (negative input is ADC GPIO pin). But limited by input voltage of the chip's PAD, the actual range is narrower. adc\_res: afe\_0xec<1:0>. Set resolution as 8/10/12/14 bits. ADC data is always 16-bit format no matter what the resolution is set. For example, 14 bits resolution indicates ADC data consists of 14-bit valid data and 2-bit sign extension bit. adc\_tsamp: afe\_0xee<3:0>. Set sampling time which determines the speed to stabilize input signals. Sampling time (marked as $T_{samp}$ ) = adc\_tsamp / $F_{ADC, clk}$ . The lower sampling cycle, the shorter ADC convert time. #### 13.3.3 "Capture" State For the Misc channel, at the beginning of its "Capture" state, a "run" signal is issued automatically to start an ADC sampling and conversion process; at the end of "Capture" state, ADC output data is captured. The length of "Capture" state is configurable via the analog register r\_max\_mc[9:0] (afe\_0xf1<7:6>, afe\_0xef<7:0>). "Capture" state duration for Misc channel (marked as $T_{cd}$ ) = r\_max\_mc / 24MHz. - The "VLD" bit (afe\_0xf6<0>) will be set as 1b'1 at the end of "Capture" state to indicate the ADC data is valid, and this flag bit will be cleared automatically. - The 16-bit ADC output data can be read from the analog register adc\_dat[15:0] (afe\_0xf8<7:0>, afe\_0xf7<7:0>) while the - afe\_0xf3<0> is set as 1b'0 (default). If the afe\_0xf3<0> is set as 1b'1, the data in the afe\_0xf8 and afe\_0xf7 won't be updated. DS-TLSR9515-E5 149 Ver 0.8.4 **NOTE:** The total duration " $T_{td}$ ", which is the sum of the length of "Set" state and "Capture" state, determines the sampling rate. Sampling frequency (marked as $F_s$ ) = 1 / $T_{td}$ ## 13.3.4 Usage Case with Detailed Register Setting This case introduces the register setting details for Misc channel sampling. In this case, afe\_0xf2<2> should be set as 1b'1, so as to enable the Misc channel, while the max state index should be set as "2" by setting afe\_0xf2<5:4> as 0x2. The total duration (marked as $T_{td}$ ) = (1\*r\_max\_s+1\*r\_max\_mc) / 24MHz. Table 13-1 Overall Register Setting | Function | Register Setting | | | |--------------------------------------------------------|-------------------------------------------------------------------------------|--|--| | Power on the ADC | afe_0xfc<5> = 1b'0 | | | | Set F <sub>ADC clk</sub> (ADC clock frequency) as 4MHz | afe_0xf4<2:0> = 5 | | | | Set 1 ADC_clk (ADC clock frequency) 65 411112 | $F_{ADC\_Clk} = 24MHz/(5+1) = 4 MHz$ | | | | Enable the Misc channel | afe_0xf2<2> = 1b'1 | | | | Set the max state index as "2" | afe_0xf2<5:4> = 2b'10 | | | | Sot T ("Sot" state duration) | afe_0xf1<3:0> = 10 | | | | Set T <sub>sd</sub> ("Set" state duration) | T <sub>sd</sub> = r_max_s/24 MHz = 10/24 MHz = 0.417 μs | | | | Set T <sub>cd</sub> ("Capture" state duration) | afe_0xf1<7:6> = 1, afe_0xef<7:0> = 0xea | | | | Set Icd ( Captore State oblation) | $T_{cd} = r_{max_mc}[9:0]/24 \text{ MHz} = 490/24 \text{ MHz} = 20.417 \mu s$ | | | | T <sub>td</sub> (total duration) | T <sub>td</sub> = (1*r_max_s+1*r_max_mc) / 24 MHz = 500/24 MHz = | | | | t <sub>d</sub> (total dalation) | 20.83 μs | | | | F <sub>s</sub> (Sampling frequency) | $F_s = 1 / T_{td} = 24 \text{ MHz}/500 = 48 \text{ kHz}$ | | | | Set differential input | afe_0xec<6> = 1 | | | | Set input channel | afe_Oxeb = Ox56 | | | | Set input channel | Select PB[4] as positive input and PB[5] as negative input | | | | Set reference voltage V <sub>REF</sub> | afe_0xea<1:0> = 2 | | | | Set reference voltage v <sub>REF</sub> | V <sub>REF</sub> =1.2V | | | | | afe_0xfa<7:6> = 0 | | | | Set scaling factor for ADC analog input | scaling factor: 1 | | | | | ADC maximum input range: -1.2V ~ +1.2V | | | | Set resolution | afe_0xec<1:0> = 3 | | | | | resolution: 14 bits | | | DS-TLSR9515-E5 150 Ver 0.8.4 | Function | Register Setting | | |-----------------------------------------------------------------------|-----------------------------------------------------------|--| | Set T <sub>samp</sub> (determines the speed to stabilize input before | afe_0xee<3:0> = 3 | | | sampling) | $T_{samp}$ = adc_tsamp / $F_{ADC\_clk}$ = 12/4 MHz = 3 µs | | # 13.4 Battery Voltage Sampling The SoC use GPIO input for battery voltage sampling, by setting register afe\_0xeb<7:4>, user can choose which GPIO port to use. Register afe\_0xeb<3:0> should be set to 0xf. # 13.5 Register Table Table 13-2 SAR ADC Registers | Address | Default Value | Description | |---------------|---------------|------------------------------------------------------------| | | | Select V <sub>REF</sub> for Misc channel | | | | OxO: rsvd | | afe_0xea<1:0> | 00 | 0x1: 0.9V | | | | 0x2: 1.2V | | | | Ox3: rsvd | | afe_0xea<7:2> | | rsvd | | | | Select negative input for Misc channel: | | | | OxO: No input | | | | Ox1: B<0> | | | | 0x2: B<1> | | | | | | | | 0x8: B<7> | | afe_0xeb<3:0> | 0000 | 0x9: C<4> | | | | Oxa: C<5> | | | | Oxb: rsvd | | | | Oxc: rsvd | | | | Oxd: old tempsensor_n (Temperature sensor negative output) | | | | Oxe:new tempsensor_n (Temperature sensor negative output) | | | | Oxf: Ground | DS-TLSR9515-E5 151 Ver 0.8.4 | Address | Default Value | Description | |---------------|---------------|------------------------------------------------------------------| | | | Select positive input for Misc channel: | | | | OxO: No input | | | | Ox1: B <o></o> | | | | 0x2: B<1> | | | | | | | | 0x8: B<7> | | afe_0xeb<7:4> | 0000 | 0x9: C<4> | | | | Oxa: C<5> | | | | Oxb: rsvd | | | | Oxc: rsvd | | | | Oxd:old tempsensor_p (Temperature sensor positive output) | | | | Oxe: new tempsensor_n (Temperature sensor negative output) | | | | Set resolution for Misc channel | | | | OxO: 8bits | | afe_0xec<1:0> | 11 | Ox1: 10bits | | | | Ox2: 12bits | | | | Ox3: 14bits | | afe_0xec<5:2> | - | rsvd | | | | Select input mode for Misc channel. | | afe_Oxec<6> | 0 | 0: rsvd | | | | 1: differential mode | | afe_Oxec<7> | - | rsvd | | | | Number of ADC clock cycles in sampling phase for Misc channel to | | | | stabilize the input before sampling: | | | 0000 | OxO: 3 cycles | | afe_0xee<3:0> | | Ox1: 6 cycles | | 310_0,00 | | Ox2: 9 cycles | | | | Ox3: 12 cycles | | | | | | | | Oxf: 48 cycles | | Address | Default Value | Description | |----------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------| | afe_0xef<7:0> | - | r may mello. Oleonyos to set length of "speture" state for Miss | | afe_0xf0<7:0> | - | r_max_mc[9:0]serves to set length of "capture" state for Misc channel. | | afe_0xf1<3:0> | - | r_max_s serves to set length of "set" state for Misc channel. | | afe_0xf1<5:4> | - | Note: State length indicates number of 24M clock cycles occupied | | afe_0xf1<7:6> | - | by the state. | | afe_0xf2<0> | - | rsvd | | afe_0xf2<1> | - | rsvd | | afe_0xf2<2> | - | Enable Misc channel sampling. 1: enable | | ofo Ovf2 <2: | 0 | O: enable write to core | | afe_Oxf2<3> | Ü | 1: disable write to core | | afe_0xf2<5:4> | 00 | Set total length for sampling state machine (i.e. max state index) | | afe_0xf2<7> | - | rsvd | | afe_0xf3<0> | 0 | O: sample ADC data to afe_Oxf8 and afe_Oxf7 | | 016_0X13<0> | | 1: not sample ADC data to afe_0xf8 and afe_0xf7 | | afe_0xf3<7:2> | - | rsvd | | afe_0xf4<2:0> | 011 | ADC clock (derive from external 24M crystal) | | | | ADC clock frequency = 24M/(adc_clk_div+1) | | afe_0xf4<7:3>- | - | rsvd | | afe_0xf5<7:0> | - | rsvd | | afe_0xf6<0> | - | [0]: vld, ADC data valid status bit (This bit will be set as 1 at the end of capture state to indicate the ADC data is valid, and will be | | | | cleared when set state starts.) | | afe_0xf6<7:1> | - | rsvd | | afe_0xf7<7:0> | | Read only | | | | [7:0]: Misc adc dat[7:0] | | afe_0xf8<7:0> | | Read only | | | | [7:0]: Misc adc_dat[15:8] | | afe_0xf9<1:0> | - | rsvd | | Address | Default Value | Description | |----------------|---------------|-----------------------------------------| | | | Vbat divider select | | | | sel_vbatdiv[1:0] Vbatdiv | | afe_0xf9<3:2> | 0 | 0x0 OFF | | ale_Oxi9<3.2> | O | Ox1 VBAT/4 | | | | 0x2 VBAT/3 | | | | Ox3 rsvd | | | | Analog Test Bus (ATB) select | | | | sel_atb[1:0] ATB | | -f- 0f0F 4. | 00 | 0x0 NONE | | afe_0xf9<5:4> | 00 | Ox1 atb<0> | | | | 0x2 atb<1> | | | | 0x3 atb<2> | | afe_0xf9<7:6> | - | rsvd | | | 0 | Comparator preamp bias current trimming | | | | itrim_preamp[1:0] Ibias | | afa Oufa (1.0) | | 0x0 75% | | afe_0xfa<1:0> | | 0x1 100% | | | | Ox2 125% | | | | 0x3 150% | | | | Vref buffer bias current trimming of | | | | itrim_vrefbuf[1:0] Ibias | | - (- O (- 2 2 | 0 | 0x0 75% | | afe_0xfa<3:2> | 0 | Ox1 100% | | | | Ox2 125% | | | | 0x3 150% | | | | Vref buffer bias current trimming of | | | 0 | itrim_vcmbuf[1:0] Ibias | | ofo OxfoxE.4. | | 0x0 75% | | afe_0xfa<5:4> | | Ox1 100% | | | | 0x2 125% | | | | 0x3 150% | | Address | Default Value | Description | |---------------|---------------|-----------------------------------------------------------------------------------------------------------| | afe_0xfa<7:6> | 0 | Analog input pre-scaling select sel_ai_scale[1:0]: scaling factor 0x0: 1 0x1: rsvd 0x2: rsvd 0x3: 1/8 | | afe_0xfc<4> | 0 | rsvd | | afe_Oxfc<5> | 1 | Power down ADC 1: Power down O: Power up | # 14 Temperature Sensor The SoC integrates a temperature sensor and it's used in combination with the SAR ADC to detect real-time temperature. The temperature sensor is disabled by default. The analog register afe $_0x06<2>$ should be set as 1b'0 to enable the temperature sensor. | Address | R/W | Description | Default Value | |----------|-----|---------------------------------|---------------| | | | [0]: Power down of temp sensor: | | | afe_0x06 | R/W | 1: Power down | Ox1 | | | | O: Power up | | Table 14-1 Analog Register for Temperature Sensor The temperature sensor embeds a pnp transistor. It takes the real-time temperature (T) as input, and outputs voltage drop ( $V_{EB}$ ) signals of pnp transistor as positive and negative output respectively. Real-time temperature T VEB Positive output VE Differential mode SAR ADC Negative output VB Figure 14-1 Block Diagram of Temperature Sensor The voltage drop $V_{EB}$ signals is determined by the real-time temperature T, as shown below: $$V_{EB} = 884mV - 1.4286mV/^{\circ}C * (T - (-40^{\circ}C))$$ = $884mV - 1.4286mV/^{\circ}C * (T + 40^{\circ}C)$ In this formula, "884mV" indicates the value of $V_{EB}$ at the temperature of -40 To detect the temperature, the positive and negative output of the temperature sensor should be enabled as the input channels of the SAR ADC. The ADC will convert the $V_{EB}$ signals into digital signal. The ADC should be configured as differential mode, and the positive and negative output of the temperature sensor should be configured as differential input of the ADC. The ADC should initiate one operation and obtain one output signal (ADCOUT); therefore, $$V_{EB} = \frac{ADCOUT}{2^{N}-1} * V_{REF}$$ In the formula, "N" and "V<sub>REF</sub>" indicate the selected resolution and reference voltage of the SAR ADC. Then the real-time temperature T can be calculated according to the $V_{EB}$ . # 15 Low Power Comparator The SoC embeds a low power comparator. This comparator takes two inputs: input derived from external PortB (PB[1]~PB[7]), and reference input derived from internal reference, PB[0], PB[3], AVDD3 or float. By comparing the input voltage multiplied by selected scaling coefficient with reference input voltage, the low power comparator will output high or low level accordingly. Figure 15-1 Block Diagram of Low Power Comparator ### 15.1 Power On/Down The low power comparator is powered down by default. The analog register afe\_0x07<3> serves to control power state of the low power comparator: By clearing this bit, this comparator will be powered on; by setting this bit to 1b'1, this comparator will be powered down. To use the low power comparator, first set afe $_0x07<3>$ as 1b'0, then the 32K RC clock source is enabled as the comparator clock. ### 15.2 Select Input Channel Input channel is selectable from the PortB (PB<1> ~ PB<7>) via the analog register afe\_0x0d<2:0>. ## 15.3 Select Mode and Input Channel for Reference Generally, it's needed to clear both the afe\_0x0b<3> and afe\_0x0d<7> to select the normal mode. In normal mode, the internal reference is derived from UVLO and has higher accuracy, but current bias is larger (10 $\mu$ A); DS-TLSR9515-E5 157 Ver 0.8.4 reference voltage input channel is selectable from internal reference of 972 mV, 921 mV, 870 mV and 819 mV, as well as PB<0>, PB<3>, AVDD3 and float. To select the low power mode, both the afe\_0x0b<3> and afe\_0x0d<7> should be set as 1b'1. In low power mode, the internal reference is derived from Bandgap and has lower accuracy, but current bias is decreased to 50 nA; reference voltage input channel is selectable from internal reference of 964 mV, 913 mV, 862 mV and 810 mV, as well as PB<0>, PB<3>, AVDD3 and float. ## 15.4 Select Scaling Coefficient Equivalent reference voltage equals the selected reference input voltage divided by scaling coefficient. The analog register afe\_0x0b<5:4> serves to select one of the four scaling options: 25%, 50%, 75% and 100%. ### 15.5 Low Power Comparator Output The low power comparator output is determined by the comparison result of the value of [input voltage \*scaling] and reference voltage input. The comparison principle is shown as below: - If the value of [input voltage \*scaling] is larger than reference voltage input, the output will be low ("0"). - If the value of [input voltage \*scaling] is lower than reference voltage input, the output will be high ("1"). - If the value of [input voltage \*scaling] equals reference voltage input, or input channel is selected as float, the output will be uncertain. User can read the output of the low power comparator via the analog register afe\_0x88[6]. The output of the low power comparator can be used as signal to wakeup system from low power modes. ### 15.6 Register Description Table 15-1 Analog Register Related to Low Power Comparator | Address | R/W | Description | Default Value | |----------|-----|------------------------------------------------------------------------|---------------| | afe_0x06 | R/W | [1]: Power down of low current comparator: 1: Power down O: Power up | Ox1 | DS-TLSR9515-E5 158 Ver 0.8.4 | Address | R/W | Description | Default Value | |----------|--------|------------------------------------------------|---------------| | | | [3]: comp_ref_mod_sel | | | | | reference mode select: | | | | | 1: ref from BG | | | | | 0: ref from UVLO | | | afa OvOb | D /\A/ | [5:4]: comp_refscale<1:0> | | | afe_0x0b | R/W | reference scale select: | _ | | | | 11: 1 | | | | | 10: 3/4 | | | | | 01: 1/2 | | | | | 00: 1/4 | | | | | [2:0]: lc_comp_chsel<2:0> | | | | | channel select of lc comparator: | | | | | 0x000 -> AIN<0> | | | | | | | | | | 0x111 -> AIN<7> | | | | | [3]: lc_comp_vbus_inen | | | | | inner detect point enable: | | | | | 1: enable | | | | | 0: disable | | | | | [6:4]: lc_comp_refsel<2:0> | | | | | channel select of lc comparator: | | | afe_OxOd | R/W | 0x000 -> float | - | | | | 0x001 -> 974mV | | | | | 0x010 -> 923mV | | | | | 0x011 -> 872mV | | | | | 0x100 -> 820mV | | | | | 0x101 -> AIN_in<0> | | | | | 0x110 -> AIN_in<1> | | | | | Ox111 -> avddh | | | | | [7]: lc_comp_pd_10u | | | | | power down of 10u current to voltage reference | | | | | 1: power down | | | | | O: active | | ## 16 AES The SoC embeds AES module with encryption and decryption function. The input 128-bit plaintext in combination of key is converted into the final output ciphertext via encryption; the 128-bit ciphertext in combination of key can also be converted into 128-bit plaintext via decryption. Software stores the block to encrypt, at AESPTR address in the SRAM. The block size to encrypt is always considered to equal 128-bit. Software defines the input key setting its value in AESKEY<> registers. Once the settings done, Software starts AES-128 use by writing a 1 in AES\_START. On normal termination, the Software receives a crypt\_irq. When the process ends the Software can find encrypted data at AESPTR+16 address as shown in figure below (considering byte address memory). Figure 16-1 AES Address AES related registers are listed as following: Table 16-1 AES Registers | Address | Туре | Description | Reset Value | |---------|------|------------------|-------------| | 0xb0 | R/W | Bit[O] AES_START | 0x00 | | 0xb4 | R/W | [31:0] KEYO | 0x00 | | 0xb8 | R/W | [31:0] KEY1 | 0x00 | | Oxbc | R/W | [31:0] KEY2 | 0x00 | | 0xc0 | R/W | [31:0] KEY3 | 0x00 | | 0xc4 | R/W | [15:0] AESPTR | 0x00 | # 17 Public Key Engine (PKE) The SoC embeds Public Key Engine Standard Performance acceleration module and this section describes its function and use. #### 17.1 Calculation Model Overview Public Key Engine (PKE) is specifically designed to accelerate large digital-to-analog operations in public key cryptographic operations. PKE SP-ECC is a version optimized for the elliptic curve algorithm. In this version, the following features are available. - Support different bit width ECC (prime field): 192, 256 bits - Support curve parameters: NIST p192, NIST p256, X25519, EdDSA ## 17.2 Function Description #### 17.2.1 Module Description There are a large number of large digital-to-analog operations in public key cryptographic operations. PKE is designed to accelerate large digital-to-analog operations involved in RSA and Elliptic Curve Cryptography (ECC) operations in public key cryptography. Recently PKE can directly complete modular exponentiation in RSA and point multiplication in ECC. The CPU can query the operation of the PKE by polling or interrupting. The PKE includes one program memory unit (ROM), one instruction arithmetic unit (IEU), one 32-bit arithmetic unit (ALU), two pseudo-double-ended data RAMs, one register combination with interface module. According to different register configurations, PKE can perform the following operations with different precisions: • ECC (Prime field): 192 and 256 bits In addition, the calculation of the PKE is finished in the form of Microcode and the Microcode is stored in the program storage unit. Therefore, different kind of public key cryptographic calculations can be implemented by pouring different microcode into the program storage unit. For instance, a high security public key algorithm instruction can be injected into a program storage unit in the PKE module in a SoC with high security requirements. Certainly these arithmetic instructions can be written to the ROM with a large program memory unit capacity. The CPU makes real-time calls according to different usage scenarios. The full microcode size is approximately 2 KB. DS-TLSR9515-E5 161 Ver 0.8.4 Figure 17-1 Block Diagram of PKE SP Module #### 17.2.2 Software Interface (Programming Model) The interfaces of the PKE SP are all mapped into the 7KB address space. The block of address mapping space mainly contains all the operands that the CPU can access. These operands contain modulus, power exponents, partial intermediate variables, and so on. In addition to this, the address map also contains control and status registers. The CPU can configure and monitor the PKE module through these control and status registers. In the operations supported by PKE, the operands are also 192 bits at minimum. Therefore, it will encounter the problem of big-endian and little-endian when putting data into data RAM in the CPU or DMA. In the PKE module, words are arranged following an order of little-endian. In PKE, the smallest operand is 32 bits (1 word), because the current ALU bit width input is 32 bits. If the operand is not word aligned, the high bit needs to be filled as 0. After the PKE receives the start command, it starts the operation. During the operation, the host computer can query the current running state through the status register, or interrupt the current operation through the control register. In addition, the result of partial intermediate operations can be obtained by accessing the data RAM address. The host computer can obtain the result of target operation finish by PKE through polling or interrupting. Data RAM supports word aligned and does not support byte alignment. DS-TLSR9515-E5 162 Ver 0.8.4 Table 17-1 Dual Port Ram Address Map | | ECC | | | |-----------------------|----------|----------|-----------| | Operand First Address | 256 bits | 512 bits | 1024 bits | | AO | 0x0400 | 0x0400 | 0x0400 | | A1 | 0x0424 | 0x0444 | 0x0484 | | A2 | 0x0448 | 0x0488 | 0x0508 | | А3 | 0x046C | 0x046C | 0x058C | | A4 | 0x0490 | 0x0510 | 0x0610 | | A5 | 0x04B4 | 0x0554 | 0x0694 | | A6 | 0x04D8 | 0x0598 | 0x0718 | | A7 | 0x04FC | 0x05DC | 0x079C | | A8 | 0x0520 | 0x0620 | 0x0820 | | A9 | 0x0544 | 0x0664 | 0x08A4 | | ВО | 0x1000 | 0x1000 | 0x1000 | | B1 | 0x1024 | 0x1044 | 0x1084 | | В2 | 0x1048 | 0x1088 | 0x1108 | | В3 | 0x106C | 0x10CC | 0x118C | | В4 | 0x1090 | 0x1110 | 0x1210 | | B5 | 0x10B4 | 0x1154 | 0x1294 | | В6 | 0x10D8 | 0x1198 | 0x1318 | | В7 | 0x10FC | 0x11DC | 0x139C | | В8 | 0x1120 | 0x1220 | 0x1420 | | В9 | 0x1144 | 0x1264 | 0x14A4 | The above table shows the address assignment of two RAMs in ECC mode. The operand registers are distributed in two blocks of data RAM, using the prefixes A and B to distinguish the two blocks of RAM. The addresses listed in the table are all CPU addressable addresses, RAM A has an address offset of 0x400, and RAM B has an address offset of 0x1000. The actual space used by RAM will be larger than the space listed in the table and some intermediate variable storage is not open to the CPU. Data will be stored in the mode of little-endian in RAM. # 17.3 Register Description The following registers' base address is 0x110000. Table 17-2 PKE Related Registers | Offset | R/W | Description | Default Value | |--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | 0x00 | W1S | PKE_CR [O] Go Start signal. When write 1 to the byte, the PKE will start running in the next clock cycle. The operation of the PKE is based on the configuration of the control registers and data registers for that clock cycle written as 1. [7:1] Rsvd | 0x00 | | 0x02 | W1S | PKE_CR2 [16] Stop Stop signal. When write 1 to the byte, PKE will stop in the next clock cycle. [23:17] Rsvd | 0x00 | | 0x05 | RW | PKE_CFG1 [8] IRQEN Interrupt enable. When the bit is set as 1, the o_irq interface is valid. Regardless of whether the bit is set as 1, the STAT register is not affected by it. [15:9] Rsvd | 0x00 | | 0x06 | RW | PKE_CFG2 [23:16] Partial_Radix Select part of BASE_RADIX to determine the bit width that the operation really needs to use during the operation. The value of this field indicates the number of words, and the bit width of the operand is PARTICAL_RADIX*32 bits. For example, if BASE_RADIX=2, PARTIAL_RADIX=6, then the bit width of the operand is (6/ (256/32))*256=192. If the operations of ECC-192 need to be processed, BASE_RADIX and PARTIAL_RADIX should be configured as shown in this example. When using operands of other bit widths, configure BASE_RADIX and PARTIAL_RADIX according to the above formula. | 0x00 | | Offset | R/W | Description | Default Value | |--------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | 0x07 | RW | PKE_CFG3 [31:27] Rsvd [26:24] Base_Radix This field indicates the bit width cardinality at which the operation is performed. At the same time, the cardinality also represents the space required for the operand to be stored in the data RAM. For ECC point operations, the value of this field should be 2. 2: 256 bits | 0x02 | | Ox10 | RW | Others: Reserved MC_PTRO [7:0] ADDR This field indicates the address of the next instruction to be executed by the PKE. This register can only be rewritten when the PKE is not working. Any write operation while the PKE is operating will be ignored. This field is also updated in real time when running the PKE and always pointing to the address of the instruction that will be executed next. Therefore, this register can also be combined with CTRL.STOP for debugging. It should be noted that the instructions are all word aligned. Therefore, the lowest 2 bits of the field are 0. When writing an instruction address to this field, it is limited to the address range of OxOO-Ox2F. The written address will proceed "And" Operation with a mask, therefore ignoring the upper 6 bits. | 0x00 | | Ox11 | RW | MC_PTR1 [11:8] ADDR See above description for [7:0] [15:12] Rsvd | 0x00 | | Offset | R/W | Description | Default Value | |--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | 0x20 | W1C | STAT [O] Done When the bit is set to 1, it indicates that the operation ends. When this bit is set as 1 from external, the bit is cleared. In addition, this bit also acts as a clear bit for the external interrupt. When the bit is high as CTRL.IRQEN is active, the external interrupt signal is also pulled high. To write 1 from external, the external interrupt is also cleared. [7:1] Rsvd | 0x00 | | 0x24 | R | RT_CODE This field is used to indicate the reason for PKE stop. If PKE is stopped because the operation is completed, then the value of this field is 0. If the value of this field is non-zero, the operation of PKE has not been completed and some exceptions have been encountered, which require external processing and the results are not available. [O]: Normal stop [1]: Termination request received (CTRL.STOP is high) [2]: No valid modular inverse result [3]: Point is not on the curve (CTRL.CMD: PVER) [4]: Invalid Microcodeothers: Reserved | 0x00 | | 0x50 | RW | EXE_CONF0 | 0x2a | | 0x51 | R | EXE_CONF1 | 0x00 | | 0x80 | R | PKE_RBG_VERSIONO [3:0]:Sub version number. [7:4]:Main version number | 0x00 | | 0x82 | R | PKE_RBG_VERSION2 PROJECT number low | 0x00 | | 0x83 | R | PKE_RBG_VERSION3 PROJECT number high | 0x00 | # 18 True Random Number Generator (TRNG) ### 18.1 Model Overview True random number generator module contains entropy source and post processing (Deterministic Random Bit Generators, DRBG). The entropy source is designed using RO. The top block diagram of the random number generator is shown below. Bus Slave Control Entropy Source Noise Source Cond. Function DRBG Figure 18-1 Module Boundary ## 18.2 Interrupt Description The Random Bit Generator (RBG) module has the following interrupt sources: - CPU reads RBG DR without data - Data valid The above interrupts can be set by RBG\_CR. By default, the data valid interrupt is enabled. When the RBGEN of RBG\_CR is low, the interrupt signal will not be cleared. Therefore, before enabling RBGEN, it is necessary to ensure that there is no previous interrupt signal, otherwise it will affect the next interrupt. #### 18.2.1 CPU Reads RBG\_DR without Data In order to prevent the CPU from reading the invalid data, the RBG can remind the CPU to read in such a situation when there is no valid random number. In order to avoid the CPU reading the empty data, it is recommended to read the RBG\_FIFO\_SR first every time to get the random number before the CPU gets data in the current FIFO to avoid invalid data. The CPU can clear the interrupt by writing 1 to ERERR in RBG\_SR. If the write is successful, the interrupt will be cleared. When the above situation occurs again, the interrupt will be valid again. DS-TLSR9515-E5 167 Ver 0.8.4 #### 18.2.2 Data Valid RBG provides two ways to output data. When the interrupt is enabled, the random number can be read by the way of interrupting. In this design, the data in the corresponding FIFO will only be pulled up after the threshold is reached, thus the CPU can obtain multiple data at once. The threshold can be set by RBG\_FIFO\_CR. The CPU can clear the interrupt by writing 1 to DRDY of RBG\_SR. If the write is successful, the interrupt will be pulled down. The interrupt is pulled high again when the data in the FIFO reaches the threshold again. It is important to note that the interrupt will only be pulled up when the amount of data in the FIFO reaches the threshold. Therefore, the data in the FIFO exceeds the threshold firstly and then RBG module pulls up the interrupt. When the CPU doesn't obtain data or have obtained data but the amount of data remaining in the FIFO is still larger than the threshold, then clear the interrupt. Although the data in the FIFO is still larger than the threshold, it will not be interrupted. In addition, the CPU can use the RBG\_FIFO\_SR register to view the remaining data in the FIFO. It can also use this method to obtain a random number. Check the RBG\_FIFO\_SR register when the random number is needed and the number of random numbers indicated by the register can be fetched at one time. If the rate at which the CPU handles random numbers is slower than the rate at which RBG random numbers are generated, it is generally not recommended to use interrupt to obtain random numbers. ### 18.3 Usage Procedure #### 18.3.1 Normal Operation Turn off the RBG module first after the CPU works normally, that is to set RBGEN of the RBG\_CR to 0. Then it can be configured and write 1 to RBGEN after the configuration is complete to make it work normally. The CPU can configure RBG module by configuring RBG\_CR, RBG\_FIFO\_CR and other optional configuration registers. When writing 1 to RBGEN in RBG\_CR, the modification of the value of the above register will not affect the RBG. Therefore, when configuring, set the RBGEN in the RBG\_CR register after configuring other registers to enable the OSR RBG module. TRBG and DRBG can be switched by modifying RBG\_RTCR during the operation to meet different usage environments. ### 18.3.2 Entropy Source In this design, the random number generator module uses RO RNG as the entropy source. RO RNG contains modules such as random source and post-processing. RO RNG has four independent RO entropy sources. Each entropy source can choose to use its own RO CLK as the sampling clock or select the system clock as the sampling clock. The selection is determined by the input of l\_rbg\_sclk\_sel, which is high for the system clock and low for the internal RO CLK. All RO enable signals are open at the same time and some of the ROs can be turned on or off by controlling the register. ### 18.4 Register Description TRNG related registers are listed in the following table. The base address for the following registers is 0x101800. DS-TLSR9515-E5 168 Ver 0.8.4 Table 18-1 Register Description | Offset | R/W | Description | Default Value | |--------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | 0x00 | RW | TRNG_CRO [0]: Random bit generator enable. [1]: Each bit states enable for one RO SOURCEO [2]: Each bit states enable for one RO SOURCE1 [3]: Each bit states enable for one RO SOURCE2 [4]: Each bit states enable for one RO SOURCE3 | Ox1f | | 0x04 | RW | TRNG_RTCR [0]: Mode select.0: TRBG without post-processing.1: TRBG with post-processing | 0x00 | | 0x08 | R | RBG_SR [0]: Data ready. | 0x00 | | 0x0c | R | RBG_DRO rbg data | - | | OxOd | R | RBG_DR1 rbg data | - | | 0x0e | R | RBG_DR2 rbg data | - | | OxOf | R | RBG_DR3 rbg data | - | | 0x10 | R | RBG_VERSIONO [3:0]: Sub version number. [7:4]: Main version number | 0x01 | | 0x12 | RO | RBG_VERSION2 PROJECT number low | 0x3a | | 0x13 | RO | RBG_VERSION3 PROJECT number high | Oxef | | 0x80 | RW | RO_CR1_0 RO enable of RO SOURCE1.Each bit controls one RO. In total, there are 16 ROs in RW RO SOURCE 1. | Oxff | | 0x81 | RW | RO_CR1_1 RO enable of RO SOURCE1.Each bit controls one RO. In total, there are 16 ROs in RW RO SOURCE 1. | Oxff | | Offset | R/W | Description | Default Value | |--------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | 0x82 | RW | RO_CRO_O RO enable of RO SOURCEO.Each bit controls one RO. In total, there are 16 ROs in RW RO SOURCE O. | Oxff | | Ox83 | RW | RO_CRO_1 RO enable of RO SOURCEO.Each bit controls one RO. In total, there are 16 ROs in RW RO SOURCE O. | Oxff | | 0x84 | RW | RO_CR3_0 RO enable of RO SOURCE3.Each bit controls one RO. In total, there are 16 ROs in RW RO SOURCE 3. | Oxff | | 0x85 | RW | RO_CR3_1 RO enable of RO SOURCE3.Each bit controls one RO. In total, there are 16 ROs in RW RO SOURCE 3. | Oxff | | 0x86 | RW | RO_CR2_0 RO enable of RO SOURCE2.Each bit controls one RO. In total, there are 16 ROs in RW RO SOURCE 2. | Oxff | | 0x87 | RW | RO_CR2_1 RO enable of RO SOURCE2.Each bit controls one RO. In total, there are 16 ROs in RW RO SOURCE 2. | Oxff | | 0x88 | RW | FSEL [1:0]:RO sampling clock frequency division selection. OO: 4 frequency division, O1: 8 frequency division, 10: 16 frequency division, 11: 32 frequency division | 0x03 |